nginx: [emerg] cannot load certificate "/etc/letsencrypt/live/home.kretest.com/fullchain.pem": BIO_new_file() failed (SSL: error:02001002:system library:fopen:No such file or directory:fopen('/etc/letsencrypt/live/home.kretest.com/fullchain.pem','r') error:2006D080:BIO routines:BIO_new_file:no such file) nginx: configuration file /etc/nginx/nginx.conf test failed
The nginx plugin is not working; there may be problems with your existing configuration. The error was: MisconfigurationError('Error while running nginx -c /etc/nginx/nginx.conf -t.\n\nnginx: [emerg] cannot load certificate "/etc/letsencrypt/live/home.kretest.com/fullchain.pem": BIO_new_file() failed (SSL: error:02001002:system library:fopen:No such file or directory:fopen(\'/etc/letsencrypt/live/home.kretest.com/fullchain.pem\',\'r\') error:2006D080:BIO routines:BIO_new_file:no such file)\nnginx: configuration file /etc/nginx/nginx.conf test failed\n')
root@mail-test:/etc/nginx/sites-available# sudo certbot --nginx -d home.kretest.com -d www.kretest.com -d backend.kretest.com -d kretest.com -d mail.kretest.com -d teman.kretest.com Saving debug log to /var/log/letsencrypt/letsencrypt.log Plugins selected: Authenticator nginx, Installer nginx Enter email address (used for urgent renewal and security notices) (Enter 'c' to cancel): xxx@gmail.com
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - Please read the Terms of Service at https://letsencrypt.org/documents/LE-SA-v1.4-April-3-2024.pdf. You must agree in order to register with the ACME server at https://acme-v02.api.letsencrypt.org/directory - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - (A)gree/(C)ancel: a
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - Would you be willing to share your email address with the Electronic Frontier Foundation, a founding partner of the Let's Encrypt project and the non-profit organization that develops Certbot? We'd like to send you email about our work encrypting the web, EFF news, campaigns, and ways to support digital freedom. - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - (Y)es/(N)o: n Obtaining a new certificate Performing the following challenges:
# ============================================= BlobStore Implementation ================================== # Read https://james.apache.org/server/config-blobstore.html for further details
# Choose your BlobStore implementation # Mandatory, allowed values are: cassandra, s3 # *WARNING*: JAMES-3591 Cassandra is not made to store large binary content, its use will be suboptimal compared to # alternatives (namely S3 compatible BlobStores backed by for instance S3, MinIO or Ozone) implementation=s3
# ========================================= Deduplication ======================================== # If you choose to enable deduplication, the mails with the same content will be stored only once. # Warning: Once this feature is enabled, there is no turning back as turning it off will lead to the deletion of all # the mails sharing the same content once one is deleted. # Mandatory, Allowed values are: true, false deduplication.enable=false
# deduplication.family needs to be incremented every time the deduplication.generation.duration is changed # Positive integer, defaults to 1 # deduplication.gc.generation.family=1
# Duration of generation. # Deduplication only takes place within a singe generation. # Only items two generation old can be garbage collected. (This prevent concurrent insertions issues and # accounts for a clock skew). # deduplication.family needs to be incremented everytime this parameter is changed. # Duration. Default unit: days. Defaults to 30 days. # deduplication.gc.generation.duration=30days
# ========================================= Encryption ======================================== # If you choose to enable encryption, the blob content will be encrypted before storing them in the BlobStore. # Warning: Once this feature is enabled, there is no turning back as turning it off will lead to all content being # encrypted. This comes at a performance impact but presents you from leaking data if, for instance the third party # offering you a S3 service is compromised. # Optional, Allowed values are: true, false, defaults to false encryption.aes.enable=false
# Mandatory (if AES encryption is enabled) salt and password. Salt needs to be an hexadecimal encoded string #encryption.aes.password=xxx #encryption.aes.salt=73616c7479 # Optional, defaults to PBKDF2WithHmacSHA512 #encryption.aes.private.key.algorithm=PBKDF2WithHmacSHA512
# ========================================= Cassandra BlobStore Cache ====================================== # A cassandra cache can be enabled to reduce latency when reading small blobs frequently # A dedicated keyspace with a replication factor of one is then used # Cache eviction policy is TTL based # Only blobs below a given threshold will be stored. # To be noted that blobs are stored within a single Cassandra row, hence a low threshold should be used.
# Enable the cache? Optional and default to false. Must be a boolean. cache.enable=false
# Cache eviction policy is TTL based. Optional and defaults to 7 days. Must be a duration. # Valid units: ms, sec, min, hour, day, week, month, year # cache.cassandra.ttl=7days
# Timeout after which this cache should be bypassed. Optional and defaults to 100ms. Can not exceed 1 hour. # Must be a duration Valid units: ms, sec, min, hour, day, week, month, year # cache.cassandra.timeout=100ms
# Maximum size of stored objects expressed in bytes. Must be strictly positive. Defaults to 8192. # Units: bytes, Kib, MiB, GiB, TiB # cache.sizeThresholdInBytes=8 KiB
# Default bucket name # Optional, default is bucketPrefix + `default` # objectstorage.namespace=james
# ========================================= ObjectStorage on S3 ============================================= # Mandatory if you choose s3 storage service, S3 authentication endpoint #objectstorage.s3.endPoint=http://xx.xx.0.6:8000/
objectstorage.s3.endPoint=https://xxx-mail.s3.amazonaws.com/mail/ # AWS S3 åå¨æ¡¶å称 objectstorage.s3.bucketName=xxx-mail # Mandatory if you choose s3 storage service, S3 region #objectstorage.s3.region=eu-west-1 objectstorage.s3.region=us-east-1
# Mandatory if you choose aws-s3 storage service, access key id configured in S3 objectstorage.s3.accessKeyId=xxx
# Mandatory if you choose s3 storage service, secret key configured in S3 objectstorage.s3.secretKey=xx/xxx
# Optional if you choose s3 storage service: The trust store file, secret, and algorithm to use # when connecting to the storage service. If not specified falls back to Java defaults. #objectstorage.s3.truststore.path= #objectstorage.s3.truststore.type=JKS #objectstorage.s3.truststore.secret= #objectstorage.s3.truststore.algorithm=SunX509
# optional: Object read in memory will be rejected if they exceed the size limit exposed here. Size, exemple `100M`. # Supported units: K, M, G, defaults to B if no unit is specified. If unspecified, big object won't be prevented # from being loaded in memory. This settings complements protocol limits. # objectstorage.s3.in.read.limit=50M
# ============================================ Blobs Exporting ============================================== # Read https://james.apache.org/server/config-blob-export.html for further details
# Choosing blob exporting mechanism, allowed mechanism are: localFile, linshare # LinShare is a file sharing service, will be explained in the below section # Optional, default is localFile blob.export.implementation=localFile
# ======================================= Local File Blobs Exporting ======================================== # Optional, directory to store exported blob, directory path follows James file system format # default is file://var/blobExporting blob.export.localFile.directory=file://var/blobExporting
# ======================================= LinShare File Blobs Exporting ======================================== # LinShare is a sharing service where you can use james, connects to an existing LinShare server and shares files to # other mail addresses as long as those addresses available in LinShare. For example you can deploy James and LinShare # sharing the same LDAP repository # Mandatory if you choose LinShare, url to connect to LinShare service # blob.export.linshare.url=http://linshare:8080
# ======================================= LinShare Configuration BasicAuthentication =================================== # Authentication is mandatory if you choose LinShare, TechnicalAccount is need to connect to LinShare specific service. # For Example: It will be formalized to 'Authorization: Basic {Credential of UUID/password}'
# Alternatively TLS keys can be supplied via PEM files tls.privateKey=file://encrypt/privkey.pem tls.certificates=file://encrypt/fullchain.pem # An optional secret might be specified for the private key # tls.secret=james72laBalle
# # If you wish to use OAuth authentication, you should provide a valid JWT public key. # The following entry specify the link to the URL of the public key file, # which should be a PEM format file. # # jwt.publickeypem.url=file://conf/jwt_publickey
# Should simple Email/query be resolved against a Cassandra projection, or should we resolve them against OpenSearch? # This enables a higher resilience, but the projection needs to be correctly populated. False by default. # view.email.query.enabled=true
# If you want to specify authentication strategies for Jmap draft version # For custom Authentication Strategy not inside package "org.apache.james.jmap.http", you have to specify its FQDN # authentication.strategy.draft=AccessTokenAuthenticationStrategy,JWTAuthenticationStrategy,QueryParameterAccessTokenAuthenticationStrategy
# If you want to specify authentication strategies for Jmap rfc-8621 version # For custom Authentication Strategy not inside package "org.apache.james.jmap.http", you have to specify its FQDN # authentication.strategy.rfc8621=JWTAuthenticationStrategy,BasicAuthenticationStrategy
# Prevent server side request forgery by preventing calls to the private network ranges. Defaults to true, can be disabled for testing. # webpush.prevent.server.side.request.forgery=false
if is_running; then echo "James started successfully with PID $(cat "$PID_FILE")." else echo "Failed to start James. Check logs for details: $JAMES_LOG" exit 1 fi }
# 停止服务 stop() { if ! is_running; then echo "James is not running." exit 1 fi
Traceback (most recent call last): File "/usr/lib/python3/dist-packages/certbot/renewal.py", line 65, in _reconstitute renewal_candidate = storage.RenewableCert(full_path, config) File "/usr/lib/python3/dist-packages/certbot/storage.py", line 465, in __init__ self._check_symlinks() File "/usr/lib/python3/dist-packages/certbot/storage.py", line 522, in _check_symlinks raise errors.CertStorageError( certbot.errors.CertStorageError: expected /etc/letsencrypt/live/kretest.com-0001/cert.pem to be a symlink Renewal configuration file /etc/letsencrypt/renewal/kretest.com-0001.conf is broken. Skipping.
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - Processing /etc/letsencrypt/renewal/kretest.com-0002.conf - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - Cert not due for renewal, but simulating renewal for dry run Plugins selected: Authenticator nginx, Installer nginx Renewing an existing certificate Performing the following challenges: http-01 challenge for kretest.com http-01 challenge for www.kretest.com Waiting for verification... Cleaning up challenges Dry run: skipping deploy hook command: /etc/letsencrypt/renewal-hooks/deploy/restart-james.sh
Traceback (most recent call last): File "/usr/lib/python3/dist-packages/certbot/renewal.py", line 65, in _reconstitute renewal_candidate = storage.RenewableCert(full_path, config) File "/usr/lib/python3/dist-packages/certbot/storage.py", line 465, in __init__ self._check_symlinks() File "/usr/lib/python3/dist-packages/certbot/storage.py", line 522, in _check_symlinks raise errors.CertStorageError( certbot.errors.CertStorageError: expected /etc/letsencrypt/live/kretest.com/cert.pem to be a symlink Renewal configuration file /etc/letsencrypt/renewal/kretest.com.conf is broken. Skipping.
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ** DRY RUN: simulating 'certbot renew' close to cert expiry ** (The test certificates below have not been saved.)
Congratulations, all renewals succeeded. The following certs have been renewed: /etc/letsencrypt/live/kretest.com-0002/fullchain.pem (success)
Additionally, the following renewal configurations were invalid: /etc/letsencrypt/renewal/kretest.com-0001.conf (parsefail) /etc/letsencrypt/renewal/kretest.com.conf (parsefail) ** DRY RUN: simulating 'certbot renew' close to cert expiry ** (The test certificates above have not been saved.) - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - 0 renew failure(s), 2 parse failure(s)
IMPORTANT NOTES: - Your account credentials have been saved in your Certbot configuration directory at /etc/letsencrypt. You should make a secure backup of this folder now. This configuration directory will also contain certificates and private keys obtained by Certbot so making regular backups of this folder is ideal. root@mail-test:/#
keytool -genkey -alias james -keyalg RSA -keystore conf/keystore
这里为了方便测试密码设置的是 q12345678
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19
root@mail-test:/data/james/james382# keytool -genkey -alias james -keyalg RSA -keystore conf/keystore Enter keystore password: Re-enter new password: What is your first and last name? [Unknown]: xen What is the name of your organizational unit? [Unknown]: xen What is the name of your organization? [Unknown]: xen What is the name of your City or Locality? [Unknown]: xen What is the name of your State or Province? [Unknown]: xen What is the two-letter country code for this unit? [Unknown]: xen Is CN=xen, OU=xen, O=xen, L=xen, ST=xen, C=xen correct? [no]: yes
root@mail-test:/data/james/james382#
修改配置
James默认配置文件在系统文件位于 ./conf 文件夹下
blob.properties
主要需要调整 ObjectStorage on S3 模块,将之前搭建好的 S3 服务器配置信息填上去
# ============================================= BlobStore Implementation ================================== # Read https://james.apache.org/server/config-blobstore.html for further details
# Choose your BlobStore implementation # Mandatory, allowed values are: cassandra, s3 # *WARNING*: JAMES-3591 Cassandra is not made to store large binary content, its use will be suboptimal compared to # alternatives (namely S3 compatible BlobStores backed by for instance S3, MinIO or Ozone) implementation=s3
# ========================================= Deduplication ======================================== # If you choose to enable deduplication, the mails with the same content will be stored only once. # Warning: Once this feature is enabled, there is no turning back as turning it off will lead to the deletion of all # the mails sharing the same content once one is deleted. # Mandatory, Allowed values are: true, false deduplication.enable=false
# deduplication.family needs to be incremented every time the deduplication.generation.duration is changed # Positive integer, defaults to 1 # deduplication.gc.generation.family=1
# Duration of generation. # Deduplication only takes place within a singe generation. # Only items two generation old can be garbage collected. (This prevent concurrent insertions issues and # accounts for a clock skew). # deduplication.family needs to be incremented everytime this parameter is changed. # Duration. Default unit: days. Defaults to 30 days. # deduplication.gc.generation.duration=30days
# ========================================= Encryption ======================================== # If you choose to enable encryption, the blob content will be encrypted before storing them in the BlobStore. # Warning: Once this feature is enabled, there is no turning back as turning it off will lead to all content being # encrypted. This comes at a performance impact but presents you from leaking data if, for instance the third party # offering you a S3 service is compromised. # Optional, Allowed values are: true, false, defaults to false encryption.aes.enable=false
# Mandatory (if AES encryption is enabled) salt and password. Salt needs to be an hexadecimal encoded string #encryption.aes.password=xxx #encryption.aes.salt=73616c7479 # Optional, defaults to PBKDF2WithHmacSHA512 #encryption.aes.private.key.algorithm=PBKDF2WithHmacSHA512
# ========================================= Cassandra BlobStore Cache ====================================== # A cassandra cache can be enabled to reduce latency when reading small blobs frequently # A dedicated keyspace with a replication factor of one is then used # Cache eviction policy is TTL based # Only blobs below a given threshold will be stored. # To be noted that blobs are stored within a single Cassandra row, hence a low threshold should be used.
# Enable the cache? Optional and default to false. Must be a boolean. cache.enable=false
# Cache eviction policy is TTL based. Optional and defaults to 7 days. Must be a duration. # Valid units: ms, sec, min, hour, day, week, month, year # cache.cassandra.ttl=7days
# Timeout after which this cache should be bypassed. Optional and defaults to 100ms. Can not exceed 1 hour. # Must be a duration Valid units: ms, sec, min, hour, day, week, month, year # cache.cassandra.timeout=100ms
# Maximum size of stored objects expressed in bytes. Must be strictly positive. Defaults to 8192. # Units: bytes, Kib, MiB, GiB, TiB # cache.sizeThresholdInBytes=8 KiB
# Default bucket name # Optional, default is bucketPrefix + `default` # objectstorage.namespace=james
# ========================================= ObjectStorage on S3 ============================================= # Mandatory if you choose s3 storage service, S3 authentication endpoint #objectstorage.s3.endPoint=http://xx.xx.0.6:8000/
objectstorage.s3.endPoint=https://xxx-mail.s3.amazonaws.com/mail/ # AWS S3 åå¨æ¡¶å称 objectstorage.s3.bucketName=xxx-mail # Mandatory if you choose s3 storage service, S3 region #objectstorage.s3.region=eu-west-1 objectstorage.s3.region=us-east-1
# Mandatory if you choose aws-s3 storage service, access key id configured in S3 objectstorage.s3.accessKeyId=xxx
# Mandatory if you choose s3 storage service, secret key configured in S3 objectstorage.s3.secretKey=xx/xxx
# Optional if you choose s3 storage service: The trust store file, secret, and algorithm to use # when connecting to the storage service. If not specified falls back to Java defaults. #objectstorage.s3.truststore.path= #objectstorage.s3.truststore.type=JKS #objectstorage.s3.truststore.secret= #objectstorage.s3.truststore.algorithm=SunX509
# optional: Object read in memory will be rejected if they exceed the size limit exposed here. Size, exemple `100M`. # Supported units: K, M, G, defaults to B if no unit is specified. If unspecified, big object won't be prevented # from being loaded in memory. This settings complements protocol limits. # objectstorage.s3.in.read.limit=50M
# ============================================ Blobs Exporting ============================================== # Read https://james.apache.org/server/config-blob-export.html for further details
# Choosing blob exporting mechanism, allowed mechanism are: localFile, linshare # LinShare is a file sharing service, will be explained in the below section # Optional, default is localFile blob.export.implementation=localFile
# ======================================= Local File Blobs Exporting ======================================== # Optional, directory to store exported blob, directory path follows James file system format # default is file://var/blobExporting blob.export.localFile.directory=file://var/blobExporting
# ======================================= LinShare File Blobs Exporting ======================================== # LinShare is a sharing service where you can use james, connects to an existing LinShare server and shares files to # other mail addresses as long as those addresses available in LinShare. For example you can deploy James and LinShare # sharing the same LDAP repository # Mandatory if you choose LinShare, url to connect to LinShare service # blob.export.linshare.url=http://linshare:8080
# ======================================= LinShare Configuration BasicAuthentication =================================== # Authentication is mandatory if you choose LinShare, TechnicalAccount is need to connect to LinShare specific service. # For Example: It will be formalized to 'Authorization: Basic {Credential of UUID/password}'
<!-- Licensed to the Apache Software Foundation (ASF) under one or more contributor license agreements. See the NOTICE file distributed with this work for additional information regarding copyright ownership. The ASF licenses this file to you under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. -->
<!-- Read https://james.apache.org/server/config-mailetcontainer.html for further details -->
<mailetcontainer enableJmx="true">
<context> <!-- When the domain part of the postmaster mailAddress is missing, the default domain is appended. You can configure it to (for example) <postmaster>postmaster@myDomain.com</postmaster> --> <postmaster>postmaster</postmaster> </context>
<processor state="relay-denied" enableJmx="true"> <mailet match="All" class="MetricsMailet"> <metricName>mailetContainerRelayDenied</metricName> </mailet> <mailet match="All" class="Bounce"> <attachment>none</attachment> </mailet> <mailet match="All" class="ToRepository"> <repositoryPath>cassandra://var/mail/relay-denied/</repositoryPath> <notice>Warning: You are sending an e-mail to a remote server. You must be authenticated to perform such an operation</notice> </mailet> </processor>
root@mail-test:/data/james/james-project/server/apps/webadmin-cli# ./james-cli --url http://127.0.0.1:9999 domain create kretest.com SLF4J: No SLF4J providers were found. SLF4J: Defaulting to no-operation (NOP) logger implementation SLF4J: See https://www.slf4j.org/codes.html#noProviders for further details. feign.RetryableException: Unexpected end of file from server executing PUT http://127.0.0.1:9999/domains/kretest.com at feign.FeignException.errorExecuting(FeignException.java:268) at feign.SynchronousMethodHandler.executeAndDecode(SynchronousMethodHandler.java:131) at feign.SynchronousMethodHandler.invoke(SynchronousMethodHandler.java:91) at feign.ReflectiveFeign$FeignInvocationHandler.invoke(ReflectiveFeign.java:100) at com.sun.proxy.$Proxy9.createADomain(Unknown Source) at org.apache.james.webadmin.httpclient.DomainClient.createADomain(DomainClient.java:43) at org.apache.james.cli.domain.DomainCreateCommand.call(DomainCreateCommand.java:41) at org.apache.james.cli.domain.DomainCreateCommand.call(DomainCreateCommand.java:28) at picocli.CommandLine.executeUserObject(CommandLine.java:1953) at picocli.CommandLine.access$1300(CommandLine.java:145) at picocli.CommandLine$RunLast.executeUserObjectOfLastSubcommandWithSameParent(CommandLine.java:2358) at picocli.CommandLine$RunLast.handle(CommandLine.java:2352) at picocli.CommandLine$RunLast.handle(CommandLine.java:2314) at picocli.CommandLine$AbstractParseResultHandler.execute(CommandLine.java:2179) at picocli.CommandLine$RunLast.execute(CommandLine.java:2316) at picocli.CommandLine.execute(CommandLine.java:2078) at org.apache.james.cli.WebAdminCli.execute(WebAdminCli.java:79) at org.apache.james.cli.WebAdminCli.main(WebAdminCli.java:67) Caused by: java.net.SocketException: Unexpected end of file from server at java.base/sun.net.www.http.HttpClient.parseHTTPHeader(HttpClient.java:917) at java.base/sun.net.www.http.HttpClient.parseHTTP(HttpClient.java:724) at java.base/sun.net.www.http.HttpClient.parseHTTPHeader(HttpClient.java:914) at java.base/sun.net.www.http.HttpClient.parseHTTP(HttpClient.java:724) at java.base/sun.net.www.protocol.http.HttpURLConnection.getInputStream0(HttpURLConnection.java:1652) at java.base/sun.net.www.protocol.http.HttpURLConnection.getInputStream(HttpURLConnection.java:1557) at java.base/java.net.HttpURLConnection.getResponseCode(HttpURLConnection.java:527) at feign.Client$Default.convertResponse(Client.java:110) at feign.Client$Default.execute(Client.java:106) at feign.SynchronousMethodHandler.executeAndDecode(SynchronousMethodHandler.java:121) ... 16 more
root@mail-test:/data/james/james-project/server/apps/webadmin-cli# ./james-cli --url http://127.0.0.1:8000 domain create kretest.com SLF4J: No SLF4J providers were found. SLF4J: Defaulting to no-operation (NOP) logger implementation SLF4J: See https://www.slf4j.org/codes.html#noProviders for further details. root@mail-test:/data/james/james-project/server/apps/webadmin-cli#
查看域列表
1
./james-cli --url http://127.0.0.1:8000 domain list
1 2 3 4 5 6 7
root@mail-test:/data/james/james-project/server/apps/webadmin-cli# ./james-cli --url http://127.0.0.1:8000 domain list SLF4J: No SLF4J providers were found. SLF4J: Defaulting to no-operation (NOP) logger implementation SLF4J: See https://www.slf4j.org/codes.html#noProviders for further details. kretest.com localhost root@mail-test:/data/james/james-project/server/apps/webadmin-cli#
添加用户
1
./james-cli --url http://127.0.0.1:9999 user create <username> --password
示例
1 2 3 4 5 6
root@mail-test:/data/james/james-project/server/apps/webadmin-cli# ./james-cli --url http://127.0.0.1:8000 user create x@xx.com --password Enter value for --password (Password): SLF4J: No SLF4J providers were found. SLF4J: Defaulting to no-operation (NOP) logger implementation SLF4J: See https://www.slf4j.org/codes.html#noProviders for further details. The user was created successfully