{"id":48,"date":"2025-01-19T23:20:52","date_gmt":"2025-01-19T15:20:52","guid":{"rendered":"https:\/\/zhang.bo.de.com\/page\/?p=48"},"modified":"2025-01-19T23:20:52","modified_gmt":"2025-01-19T15:20:52","slug":"postfixdovecotmysql%e5%ae%89%e8%a3%85","status":"publish","type":"post","link":"https:\/\/zhang.bo.de.com\/page\/2025\/01\/19\/48.html","title":{"rendered":"postfix+dovecot+mysql\u5b89\u88c5"},"content":{"rendered":"<p>&nbsp;<\/p>\n<h2 id=\"articleHeader8\">MySQL\u5b89\u88c5\u53ca\u914d\u7f6e<\/h2>\n<p>\u672c\u4f8b\u4e2d\u6211\u4eec\u4f7f\u7528MySQL\u6570\u636e\u5e93\u4fdd\u5b58Postfix\u9700\u8981\u670d\u52a1\u7684\u865a\u62df\u57df\u540d\u3001\u7528\u6237\u5e10\u53f7\u53ca\u5bc6\u7801\u3001\u90ae\u4ef6\u522b\u540d\u4e09\u4e2a\u91cd\u8981\u7684\u4fe1\u606f\u3002<\/p>\n<blockquote><p>\u8bf7\u6ce8\u610f\uff1a<br \/>\n\u5176\u5b9ePostfix\u548cDovecot\u662f\u5b8c\u5168\u53ef\u4ee5\u4e0d\u4f7f\u7528\u6570\u636e\u5e93\u7684\uff0c\u4e8c\u8005\u90fd\u53ef\u4ee5\u901a\u8fc7\u5404\u79cd\u914d\u7f6e\u6587\u4ef6\u5b8c\u6210\u300c\u96f6\u6570\u636e\u5e93\u300d\u7684\u90ae\u4ef6\u670d\u52a1\u5668\u3002\u4f46\u662f\uff0c\u65e2\u7136\u53ef\u4ee5\u4f7f\u7528\u6570\u636e\u5e93\u8fd9\u4e48\u65b9\u4fbf\uff0c\u4e3a\u4ec0\u4e48\u4e0d\u7528\u5462\uff1f\u5c06\u8fd9\u4e9b\u9700\u8981\u914d\u7f6e\u7684\u4fe1\u606f\u5b58\u50a8\u5728\u6570\u636e\u5e93\u4e2d\u300c\u5982\uff1a\u7528\u6237\u5e10\u53f7\u53ca\u5bc6\u7801\u7b49\u300d\uff0c\u5bf9\u4eca\u540e\u7684\u7ef4\u62a4\u6765\u8bf4\u662f\u975e\u5e38\u65b9\u4fbf\u7684\u4e8b\u60c5\u3002\u4e0d\u662f\u4e48\uff1f\uff01<\/p><\/blockquote>\n<h3 id=\"articleHeader9\">MySQL\u5b89\u88c5<\/h3>\n<p>\u5728Ubuntu\u79cd\u5b89\u88c5\u8f6f\u4ef6\uff0c\u662f\u518d\u7b80\u5355\u4e0d\u8fc7\u7684\u4e8b\u60c5\u4e86\u3002\u5b89\u88c5MySQL\u8bf7\u5728\u547d\u4ee4\u884c\u4e2d\u6267\u884c\u5982\u4e0b\u547d\u4ee4\uff1a<\/p>\n<pre>apt-get install mysql-server<\/pre>\n<p>\u5b89\u88c5\u8fc7\u7a0b\u4e2d\u4f1a\u9700\u8981\u4f60\u8f93\u5165\u4e24\u6b21MySQL\u7684root\u53e3\u4ee4\uff0c\u8bf7\u7262\u8bb0\u8be5\u53e3\u4ee4<\/p>\n<p>&nbsp;<\/p>\n<h3 id=\"articleHeader10\">\u65b0\u5efa\u6570\u636e\u5e93\u53ca\u7528\u6237<\/h3>\n<p>\u63a5\u4e0b\u6765\uff0c\u6211\u4eec\u9700\u8981\u65b0\u5efa\u4e00\u4e2aMySQL\u7528\u6237\u53ca\u4e00\u4e2a\u6570\u636e\u5e93\uff1a<\/p>\n<ol>\n<li>\u4f7f\u7528root\u53e3\u4ee4\u767b\u5f55MySQL\n<pre>mysql -u root -p<\/pre>\n<\/li>\n<li>\u8f93\u5165root\u53e3\u4ee4<\/li>\n<li>\u65b0\u5efa\u4e00\u4e2a\u6570\u636e\u5e93\uff0c\u540d\u79f0\u53eb\u505amailserver\uff1a\n<pre>create database mailserver character set utf8;<\/pre>\n<\/li>\n<li>\u8f93\u5165\u5982\u4e0b\u547d\u4ee4\u4ee5\u65b0\u5efa\u4e00\u4e2a\u7528\u6237mailserver\uff0c\u5e76\u6307\u5b9a\u5bc6\u7801\u4e3amailserver123\uff1a\n<pre>create user mailserver@'localhost' identified by 'mailserver123';<\/pre>\n<\/li>\n<li>\u5c06\u6570\u636e\u5e93mailserver\u7684\u6240\u6709\u6743\u9650\u8d4b\u7ed9\u7528\u6237mailserver\uff1a\n<pre>grant all on mailserver.* to mailserver@'localhost' identified by 'mailserver123';<\/pre>\n<\/li>\n<li>\u9000\u51faroot\u7528\u6237\uff1a\n<pre>exit;<\/pre>\n<\/li>\n<li>\u4f7f\u7528mailserver\u7528\u6237\u767b\u5f55\uff1a\n<pre>mysql -u mailserver -p<\/pre>\n<\/li>\n<li>\u8f93\u5165mailserver\u5e10\u53f7\u7684\u53e3\u4ee4<\/li>\n<li>\u5c06\u9ed8\u8ba4\u6570\u636e\u5e93\u5207\u6362\u4e3amailserver\u6570\u636e\u5e93\uff1a\n<pre>use mailserver;<\/pre>\n<\/li>\n<\/ol>\n<h3 id=\"articleHeader11\">\u65b0\u5efa\u8868\u683c<\/h3>\n<ol>\n<li>\u8f93\u5165\u5982\u4e0bSQL\u8bed\u53e5\u4ee5\u65b0\u5efavirtual_domains\u8868\uff0c\u8be5\u8868\u662f\u672c\u5730\u670d\u52a1\u5668\u7528\u4ee5\u63a5\u6536\u90ae\u4ef6\u7684\u57df\u540d\uff1a\n<pre>CREATE TABLE `virtual_domains` (  \r\n  `id` int(11) NOT NULL auto_increment,  \r\n  `name` varchar(50) NOT NULL,  \r\n  PRIMARY KEY (`id`))  \r\n  ENGINE=InnoDB DEFAULT CHARSET=utf8;<\/pre>\n<\/li>\n<li>\u8f93\u5165\u5982\u4e0bSQL\u8bed\u53e5\u4ee5\u65b0\u5efavirtual_users\u8868\uff0c\u8be5\u8868\u90ae\u4ef6\u670d\u52a1\u5668\u7684\u7ec8\u7aef\u7528\u6237\u8868\uff0c\u8bb0\u5f55\u7528\u6237\u7684\u90ae\u4ef6\u5730\u5740\u53ca\u5bc6\u7801\u300c\u5343\u4e07\u4e0d\u8981\u4fdd\u5b58\u660e\u6587\u5bc6\u7801\u300d\uff1a\n<pre>CREATE TABLE `virtual_users` (  \r\n`id` int(11) NOT NULL auto_increment,  \r\n`domain_id` int(11) NOT NULL,  \r\n`password` varchar(106) NOT NULL,  \r\n`email` varchar(100) NOT NULL,  \r\nPRIMARY KEY (`id`),  \r\nUNIQUE KEY `email` (`email`),  \r\nFOREIGN KEY (domain_id) REFERENCES virtual_domains(id) ON DELETE CASCADE)  \r\nENGINE=InnoDB DEFAULT CHARSET=utf8;<\/pre>\n<\/li>\n<li>\u8f93\u5165\u5982\u4e0bSQL\u8bed\u53e5\u4ee5\u65b0\u5efavirtual_aliases\u8868\uff0c\u8be5\u8868\u662f\u90ae\u4ef6\u670d\u52a1\u5668\u522b\u540d\u8868\u300c\u90ae\u4ef6\u670d\u52a1\u5668\u79cd\u7684\u522b\u540dalias\u7684\u6982\u5ff5\u5927\u5bb6\u53ef\u4ee5Google\u4e00\u756a\u300d\uff1a\n<pre>CREATE TABLE `virtual_aliases` (  \r\n`id` int(11) NOT NULL auto_increment,  \r\n`domain_id` int(11) NOT NULL,  \r\n`source` varchar(100) NOT NULL,  \r\n`destination` varchar(100) NOT NULL,  \r\nPRIMARY KEY (`id`),  \r\nFOREIGN KEY (domain_id) REFERENCES virtual_domains(id) ON DELETE CASCADE)  \r\nENGINE=InnoDB DEFAULT CHARSET=utf8<\/pre>\n<h3 id=\"articleHeader12\">\u63d2\u5165\u6570\u636e<\/h3>\n<p>\u4e3a\u4e86\u4fbf\u4e8e\u67e5\u770b\u7ed3\u679c\uff0c\u63a5\u4e0b\u6765\u7ed9\u4e0a\u8ff0\u4e09\u5f20\u8868\u79cd\u63d2\u5165\u4e00\u4e9b\u6d4b\u8bd5\u6570\u636e\uff1a<\/li>\n<li>\u7ed9virtual_domains\u8868\u63d2\u5165\u6d4b\u8bd5\u6570\u636e\uff0c\u5927\u81f4\u5982\u4e0b\uff1a\n<pre>insert into virtual_domains(id,name) values(1,'mail.mydomain.com');     \r\ninsert into virtual_domains(id,name) values(2,'mydomain.com');<\/pre>\n<blockquote><p>\u8bf7\u6ce8\u610f\uff1a<br \/>\n\u4e0a\u8ff0\u8868\u79cdid\u5b57\u6bb5\u662f\u81ea\u589e\u5217\uff0c\u53ef\u4ee5\u4e0d\u8d4b\u503c\u3002\u4f46\u65e0\u8bba\u5982\u4f55\uff0c\u63a5\u4e0b\u6765\u7684\u4e24\u5f20\u8868\u79cd\u6211\u4eec\u5c06\u9700\u8981\u4e0a\u8ff0\u8868\u79cd\u7684\u9010\u6e10\u5217id\u7684\u503c\u3002\u6bd4\u5982\uff1a\u6211\u5c06\u8981\u6dfb\u52a0mydomain.com\u57df\u540d\u4e0b\u7684\u90ae\u7bb1\u5e10\u53f7\uff0c\u800cmydomain.com\u5728virtual_domains\u8868\u79cd\u7684id\u503c\u4e3a2\u3002<\/p><\/blockquote>\n<\/li>\n<li>\u7ed9virtual_users\u8868\u6dfb\u52a0\u7528\u6237\u6570\u636e\uff1a\n<pre>insert into virtual_users(id,domain_id,password,email)  \r\nvalues (1,2,ENCRYPT('zhangsan123456', CONCAT('$6$', SUBSTRING(SHA(RAND()), -16))),'zhangsan@mydomain.com');\r\n\r\n\r\ninsert into virtual_users(id,domain_id,password,email)  \r\nvalues (2,2,ENCRYPT('123456lisi', CONCAT('$6$', SUBSTRING(SHA(RAND()), -16))),'lisi@mydomain.com');<\/pre>\n<\/li>\n<li>\u7ed9virtual_aliases\u8868\u6dfb\u52a0\u522b\u540d\u6570\u636e\uff1a\n<pre>insert into virtual_aliases(id,domain_id,source,destination)  \r\nvalues (1,2,'all@mydomain.com','zhangsan@mydomain.com');\r\n\r\ninsert into virtual_aliases(id,domain_id,source,destination)  \r\nvalues (1,2,'all@mydomain.com','lisi@mydomain.com');<\/pre>\n<blockquote><p>\u8bf7\u6ce8\u610f\uff1a<br \/>\n\u901a\u8fc7\u4e0a\u8ff0\u522b\u540d\u8868\u7684\u6570\u636e\uff0c\u5f53\u6709\u4eba\u7ed9all@mydomain.com\u53d1\u9001\u90ae\u4ef6\u65f6\uff0c\u7cfb\u7edf\u5c06\u81ea\u52a8\u5c06\u90ae\u4ef6\u8f6c\u53d1\u7ed9zhangsan@mydomain.com\u548clisi@mydomain.com<br \/>\n\u8fd9\u79cd\u573a\u666f\uff0c\u5728\u516c\u53f8\u5185\u90e8\u300c\u53d1\u9001\u901a\u77e5\u300d\u7b49\u60c5\u51b5\u4e0b\u9002\u7528<\/p><\/blockquote>\n<\/li>\n<\/ol>\n<h3 id=\"articleHeader13\">\u6d4b\u8bd5\u6570\u636e<\/h3>\n<p>\u5199\u51e0\u4e2aSQL\u67e5\u8be2\u8bed\u53e5\u67e5\u770b\u4e0b\u7ed3\u679c\u5427<\/p>\n<pre>select * from virtual_domains;  \r\nselect * from virtual_users;  \r\nselect * from virtual_aliases;<\/pre>\n<h2 id=\"articleHeader14\">Postfix\u5b89\u88c5\u53ca\u914d\u7f6e<\/h2>\n<p>Postfix\u662f\u90ae\u4ef6\u53d1\u9001\u7684\u6838\u5fc3\u670d\u52a1\u5668\uff0c\u6240\u6709\u5411\u5185\u3001\u5411\u5916\u6295\u9012\u7684\u90ae\u4ef6\u90fd\u9700\u8981\u7ecf\u8fc7Postfix\u901a\u8fc7SMTP\u534f\u8bae\u5b8c\u6210\u3002\u63a5\u4e0b\u6765\u7684\u5185\u5bb9\uff0c\u5927\u5bb6\u9700\u8981\u4fee\u6539Postfix\u76f8\u5173\u7684\u4e00\u4e9b\u53c2\u6570\uff0c\u5b83\u4eec\u662f\uff1a<\/p>\n<ul>\n<li>\u544a\u8bc9Postfix\u5982\u4f55\u8fde\u63a5MySQL\u6570\u636e\u5e93\uff0c\u5e76\u8ba9Postfix\u901a\u8fc7\u6570\u636e\u5e93\u79cd\u7684\u8868\u786e\u5b9a\u6536\u53d1\u90ae\u4ef6\u7684\u57df\u540d\u3001\u7528\u6237\u5e10\u53f7\u53ca\u5bc6\u7801\u3001\u90ae\u4ef6\u522b\u540d\u7b49<\/li>\n<li>\u544a\u8bc9Postfix\u5c06\u6536\u5230\u7684\u90ae\u4ef6\u8f6c\u53d1\u7ed9Dovecot\u7684LMTP\u670d\u52a1\u4ee5\u5b8c\u6210\u672c\u5730\u6295\u9012<\/li>\n<li>\u544a\u8bc9Postfix\u6240\u6709\u7684\u8fde\u63a5\u90fd\u9700\u8981STARTTLS\u52a0\u5bc6\uff0c\u5982\u679c\u6709\u5fc5\u8981\u300c\u5e9f\u8bdd\u554a\uff0c\u5f53\u7136\u5fc5\u987b\u8fd9\u6837\u300d<\/li>\n<li>\u5f00\u653e\u672c\u5730\u7aef\u53e325\u3001465\u3001587\u4e4b\u4e00\u6216\u5168\u90e8<\/li>\n<\/ul>\n<h3 id=\"articleHeader15\">Postfix\u7684\u5b89\u88c5<\/h3>\n<p>\u5728\u547d\u4ee4\u884c\u79cd\u6267\u884c\u4ee5\u4e0b\u547d\u4ee4\u4ee5\u5b89\u88c5Postfix\uff1a<\/p>\n<pre>apt-get install postfix postfix-mysql<\/pre>\n<p>\u5b89\u88c5\u8fc7\u7a0b\u4e2d\u9700\u8981\u9009\u62e9Postfix\u7684\u7c7b\u578b\uff0c\u8bf7\u9009\u62e9Internet Site\uff1a<\/p>\n<p>&nbsp;<\/p>\n<p>Postfix\u5b89\u88c5\u8fc7\u7a0b\u4e2d\u8fd8\u4f1a\u9700\u8981\u8f93\u5165System mail name\uff0c\u8fd9\u91cc\u8bf7\u8f93\u5165\u4f60\u8981\u6536\u53d1\u90ae\u4ef6\u7684\u57df\u540d\u5730\u5740\u300c\u968f\u4fbf\u5199\u4e5f\u53ef\u4ee5\uff0c\u53cd\u6b63\u540e\u9762\u9700\u8981\u4fee\u6539\u914d\u7f6e\u6587\u4ef6\u300d<\/p>\n<h3 id=\"articleHeader16\">Postfix\u7684\u914d\u7f6e<\/h3>\n<ol>\n<li>\u5907\u4efdPostfix\u7684\u914d\u7f6e\u6587\u4ef6\/etc\/postfix\/main.cf\uff0c\u5148\uff01\n<pre>cp \/etc\/postfix\/main.cf \/etc\/postfix\/main.cf_backup_20150511<\/pre>\n<blockquote><p>\u8bf7\u6ce8\u610f<br \/>\n\u4efb\u4f55\u65f6\u5019\uff0c\u5bf9\u4efb\u4f55\u914d\u7f6e\u8fdb\u884c\u4fee\u6539\u4e4b\u524d\uff0c\u5148\u505a\u597d\u5907\u4efd\u603b\u662f\u975e\u5e38\u5fc5\u8981\u7684<br \/>\n\u540c\u65f6\uff0c\u8fd9\u4e5f\u662f\u4e00\u4e2a\u975e\u5e38\u826f\u597d\u7684\u64cd\u4f5c\u4e60\u60ef<\/p><\/blockquote>\n<\/li>\n<li>\u4f7f\u7528vi\u7f16\u8f91\u5668\u6253\u5f00\/etc\/postfix\/main.cf\u6587\u4ef6\n<pre>vi \/etc\/postfix\/main.cf<\/pre>\n<\/li>\n<li>\u6253\u5f00\u4e4b\u540e\uff0c\u6309\u4e0bi\u952e\u8fdb\u5165\u7f16\u8f91\u6a21\u5f0f<\/li>\n<li>\u9274\u4e8e\u6211\u4eec\u6ca1\u6709\u6253\u7b97\u4f7f\u7528Postfix\u505a\u7528\u6237\u7684\u6743\u9650\u9a8c\u8bc1\u300c\u4e0a\u8ff0\u51e0\u4e2a\u56fe\u79cd\u5df2\u7ecf\u5c55\u793a\u6e05\u695a\u300d\uff0c\u6211\u4eec\u5c06\u8981\u628aPostfix\u9ed8\u8ba4\u7684\u7528\u6237\u9a8c\u8bc1\u53c2\u6570\u5c4f\u853d\uff0c\u56e0\u6b64\u8bf7\u5728\u5982\u4e0b\u51e0\u884c\u524d\u8fb9\u52a0\u5165#\u7b26\u53f7\u4ee5\u6ce8\u91ca\uff1a\n<pre># TLS parameters  \r\n  #smtpd_tls_cert_file=\/etc\/ssl\/certs\/ssl-cert-snakeoil.pem  \r\n  #smtpd_tls_key_file=\/etc\/ssl\/private\/ssl-cert-snakeoil.key  #smtpd_use_tls=yes  \r\n  #smtpd_tls_session_cache_database = btree:${data_directory}\/smtpd_scache  \r\n  #smtp_tls_session_cache_database = btree:${data_directory}\/smtp_scache<\/pre>\n<\/li>\n<li>\u590d\u5236\u5982\u4e0b\u5185\u5bb9\uff0c\u5e76\u5c06\u5176\u63d2\u5165\u5230\u4e0a\u8ff0\u6ce8\u91ca\u4ee3\u7801\u4e4b\u540e\uff1a\n<pre>smtpd_tls_cert_file=\/etc\/dovecot\/dovecot.pem  \r\nsmtpd_tls_key_file=\/etc\/dovecot\/private\/dovecot.pem  \r\nsmtpd_use_tls=yes  \r\nsmtpd_tls_auth_only = yes  \r\n\r\n#Enabling SMTP for authenticated users, and handing off authentication to Dovecot  \r\nsmtpd_sasl_type = dovecot  \r\nsmtpd_sasl_path = private\/auth  \r\nsmtpd_sasl_auth_enable = yes  \r\nsmtpd_recipient_restrictions =  permit_sasl_authenticated, permit_mynetworks, reject_unauth_destination<\/pre>\n<blockquote><p>\u8bf7\u6ce8\u610f\uff1a<br \/>\n\u4e0a\u8ff0\u51e0\u4e2a\u53c2\u6570\u7684\u542b\u4e49\uff0c\u8bf7\u53c2\u7167<a href=\"http:\/\/www.postfix.org\/documentation.html\" rel=\"noopener\">Postfix\u914d\u7f6e\u6587\u6863<\/a><\/p><\/blockquote>\n<\/li>\n<li>\u6309\u7167\u5982\u4e0b\u65b9\u5f0f\u4fee\u6539mydestination\u4e00\u884c\u7684\u503c\uff1a\n<pre>mydestination = localhost<\/pre>\n<blockquote><p>\u8bf7\u6ce8\u610f\uff1a<br \/>\n\u5c06mydestination\u7684\u503c\u4fee\u6539\u4e3alocalhost\uff0c\u4ee5\u4fbfPostfix\u80fd\u591f\u901a\u8fc7MySQL\u8868\u4e2d\u76f8\u5173\u6570\u636e\u51b3\u5b9a\u9700\u8981\u63a5\u53d7\/\u53d1\u9001\u90ae\u4ef6\u7684\u57df\u540d\uff0c\u8fd9\u6837\u66f4\u5177\u6709\u901a\u7528\u6027<\/p><\/blockquote>\n<\/li>\n<li>\u5728\u6587\u6863\u79cd\u52a0\u5165\u4ee5\u4e0b\u5185\u5bb9\uff0c\u4ee5\u4fbf\u544a\u8bc9Postfix\u4e0d\u8981\u4f7f\u7528LDA\u300cLocal Delivery Agent\u300d\u8f6c\u800c\u4f7f\u7528Dovecot\u7684LMTP\u5b8c\u6210\u672c\u5730\u90ae\u4ef6\u6295\u9012\uff1a\n<pre>#Handing off local delivery to Dovecot's LMTP, and telling it where to store mail  \r\nvirtual_transport = lmtp:unix:private\/dovecot-lmtp<\/pre>\n<\/li>\n<li>\u5728\u6587\u6863\u4e2d\u52a0\u5165\u4ee5\u4e0b\u5185\u5bb9\uff0c\u4ee5\u4fbf\u544a\u8bc9Postfix\u53bbMySQL\u6570\u636e\u5e93\u79cd\u5bfb\u627e\u57df\u540d\u3001\u7528\u6237\u5e10\u53f7\u5bc6\u7801\u53ca\u90ae\u4ef6\u522b\u540d\u7b49\u4fe1\u606f\uff1a\n<pre>#Virtual domains, users, and aliases  \r\nvirtual_mailbox_domains = mysql:\/etc\/postfix\/mysql-virtual-mailbox-domains.cf  \r\nvirtual_mailbox_maps = mysql:\/etc\/postfix\/mysql-virtual-mailbox-maps.cf  \r\nvirtual_alias_maps = mysql:\/etc\/postfix\/mysql-virtual-alias-maps.cf<\/pre>\n<\/li>\n<li>\u6700\u7ec8\uff0c\u4fee\u6539\u5b8c\u6210\u4ee5\u540e\u7684\/etc\/postfix\/main.cf\u6587\u4ef6\u5927\u81f4\u5e94\u8be5\u5982\u4e0b\uff1a\n<pre># See \/usr\/share\/postfix\/main.cf.dist for a commented, more complete version    \r\n\r\n# Debian specific:  Specifying a file name will cause the first  \r\n# line of that file to be used as the name.  The Debian default  \r\n# is \/etc\/mailname.  \r\n#myorigin = \/etc\/mailname  \r\n\r\nsmtpd_banner = $myhostname ESMTP $mail_name (Ubuntu)  \r\nbiff = no  \r\n\r\n# appending .domain is the MUA's job.  \r\nappend_dot_mydomain = no  \r\n\r\n# Uncomment the next line to generate \"delayed mail\" warnings  \r\n#delay_warning_time = 4h  \r\n\r\nreadme_directory = no  \r\n\r\n# TLS parameters    \r\n#smtpd_tls_cert_file=\/etc\/ssl\/certs\/ssl-cert-snakeoil.pem \r\n#smtpd_tls_key_file=\/etc\/ssl\/private\/ssl-cert-snakeoil.key  \r\n#smtpd_use_tls=yes  \r\n#smtpd_tls_session_cache_database = btree:${data_directory}\/smtpd_scache  \r\n#smtp_tls_session_cache_database = btree:${data_directory}\/smtp_scache  \r\n\r\nsmtpd_tls_cert_file=\/etc\/dovecot\/dovecot.pem  \r\nsmtpd_tls_key_file=\/etc\/dovecot\/private\/dovecot.pem  \r\nsmtpd_use_tls=yes  \r\nsmtpd_tls_auth_only = yes  \r\n\r\n#Enabling SMTP for authenticated users, and handing off authentication to Dovecot  \r\nsmtpd_sasl_type = dovecot  \r\nsmtpd_sasl_path = private\/auth  \r\nsmtpd_sasl_auth_enable = yes  \r\nsmtpd_recipient_restrictions =  \r\n    permit_sasl_authenticated,  \r\n    permit_mynetworks,  \r\n    reject_unauth_destination  \r\n\r\n# See \/usr\/share\/doc\/postfix\/TLS_README.gz in the postfix-doc package for    \r\n# information on enabling SSL in the smtp client.      \r\nmyhostname = host.mydomain.com  \r\nalias_maps = hash:\/etc\/aliases  \r\nalias_database = hash:\/etc\/aliases  \r\nmyorigin = \/etc\/mailname  \r\n#mydestination = example.com, hostname.mydomain.com,localhost.mydomain.com, localhost  \r\nmydestination = localhost  \r\nrelayhost =  \r\n        mynetworks = 127.0.0.0\/8 [::ffff:127.0.0.0]\/104 [::1]\/128    \r\nmailbox_size_limit = 0  \r\nrecipient_delimiter = +  \r\ninet_interfaces = all  \r\n\r\n#Handing off local delivery to Dovecot's LMTP, and telling it where to store mail  \r\nvirtual_transport = lmtp:unix:private\/dovecot-lmtp  \r\n\r\n#Virtual domains, users, and aliases  \r\nvirtual_mailbox_domains = mysql:\/etc\/postfix\/mysql-virtual-mailbox-domains.cf  \r\nvirtual_mailbox_maps = mysql:\/etc\/postfix\/mysql-virtual-mailbox-maps.cf  \r\nvirtual_alias_maps = mysql:\/etc\/postfix\/mysql-virtual-alias-maps.cf<\/pre>\n<\/li>\n<li>\u6309\u4e0bESC\u952e\u5e76\u8f93\u5165\u5982\u4e0b\u5185\u5bb9\u4ee5\u4fdd\u5b58\u5e76\u9000\u51fa\n<pre>wq!<\/pre>\n<\/li>\n<li>\u65b0\u5efa\/etc\/postfix\/mysql-virtual-mailbox-domains.cf\u6587\u4ef6\u5e76\u8f93\u5165\u5982\u4e0b\u5185\u5bb9\uff1a\n<pre>user = mailserver   \r\npassword = mailserver123  \r\nhosts = 127.0.0.1  \r\ndbname = mailserver  \r\nquery = SELECT 1 FROM virtual_domains WHERE name='%s'<\/pre>\n<\/li>\n<li>\u91cd\u542fPostfix\u670d\u52a1\n<pre>service postfix restart<\/pre>\n<\/li>\n<li>\u6d4b\u8bd5\u4e0a\u8ff0\u5185\u5bb9\u662f\u5426\u6b63\u786e\uff0c\u5982\u679c\u4e0a\u8ff0\u5185\u5bb9\u914d\u7f6e\u6b63\u786e\uff0c\u5219\u5982\u4e0b\u547d\u4ee4\u6267\u884c\u540e\u8fd4\u56de\u7ed3\u679c\u5e94\u8be5\u4e3a1\uff1a\n<pre>postmap -q mydomain.com mysql:\/etc\/postfix\/mysql-virtual-mailbox-domains.cf<\/pre>\n<\/li>\n<li>\u65b0\u5efa\/etc\/postfix\/mysql-virtual-mailbox-maps.cf\u6587\u4ef6\u5e76\u8f93\u5165\u5982\u4e0b\u5185\u5bb9\uff1a\n<pre>user = mailserver    \r\npassword = mailserver123  \r\nhosts = 127.0.0.1  \r\ndbname = mailserver  \r\nquery = SELECT 1 FROM virtual_users WHERE email='%s'<\/pre>\n<\/li>\n<li>\u91cd\u542fPostfix\u670d\u52a1\n<pre>service postfix restart<\/pre>\n<\/li>\n<li>\u6d4b\u8bd5\u4e0a\u8ff0\u914d\u7f6e\u662f\u5426\u6b63\u786e\uff0c\u5982\u679c\u4e0a\u8ff0\u5185\u5bb9\u914d\u7f6e\u6b63\u786e\uff0c\u5219\u5982\u4e0b\u547d\u4ee4\u6267\u884c\u540e\u8fd4\u56de\u7ed3\u679c\u5e94\u8be5\u4e3a1\uff1a\n<pre>postmap -q lisi@mydomain.com mysql:\/etc\/postfix\/mysql-virtual-mailbox-maps.cf<\/pre>\n<\/li>\n<li>\u65b0\u5efa\/etc\/postfix\/mysql-virtual-alias-maps.cf\u6587\u4ef6\u5e76\u8f93\u5165\u5982\u4e0b\u5185\u5bb9\uff1a\n<pre>user = mailserver    \r\npassword = mailserver123  \r\nhosts = 127.0.0.1  \r\ndbname = mailserver  \r\nquery = SELECT destination FROM virtual_aliases WHERE source='%s'<\/pre>\n<\/li>\n<li>\u91cd\u542fPostfix\u670d\u52a1\n<pre>service postfix restart<\/pre>\n<\/li>\n<li>\u6d4b\u8bd5\u4e0a\u8ff0\u914d\u7f6e\u662f\u5426\u6b63\u786e\uff0c\u5982\u679c\u4e0a\u8ff0\u914d\u7f6e\u6b63\u786e\uff0c\u5219\u5982\u4e0b\u547d\u4ee4\u6267\u884c\u540e\u8fd4\u56de\u7ed3\u679c\u5e94\u8be5\u662f\u4e4b\u524d\u6dfb\u52a0\u7684\u522b\u540d\u5e10\u53f7\uff1a\n<pre>postmap -q all@mydomain.com mysql:\/etc\/postfix\/mysql-virtual-alias-maps.cf<\/pre>\n<\/li>\n<li>\u4f7f\u7528vi\u7f16\u8f91\u5668\u6253\u5f00\/etc\/postfix\/master.cf\u6587\u4ef6\u300c\u8bf7\u6ce8\u610f\u4fee\u6539\u4e4b\u524d\u5148\u5907\u4efd\u300d\uff0c\u627e\u5230submission\u548csmtps\u6240\u5728\u7684\u4e24\u884c\uff0c\u5e76\u5c06\u5176\u6ce8\u91ca\u53bb\u6389\u3002\u8fd9\u6837\u505a\u7684\u76ee\u7684\u662f\u5141\u8bb8Postfix\u901a\u8fc7587\u548c465\u7aef\u53e3\u53d1\u9001\u90ae\u4ef6<\/li>\n<li>\u91cd\u542fPostfix\u670d\u52a1\n<pre>service postfix restart<\/pre>\n<\/li>\n<\/ol>\n<p>\u641e\u5b9a\uff0cPostfix\u670d\u52a1\u5668\u5e94\u8be5\u914d\u7f6e\u5b8c\u6210\u4e86\u3002\u76f8\u4fe1\u5230\u8fd9\u91cc\u7684\u65f6\u5019\uff0c\u5df2\u7ecf\u5413\u8d70\u4e8690%\u4ee5\u4e0a\u7684\u670b\u53cb\uff0c\u5269\u4e0b\u768410%\u670b\u53cb\u4eec\uff0c\u4f60\u4eec\u662f\u597d\u6837\u7684\u3002<\/p>\n<h2 id=\"articleHeader17\">Dovecot\u5b89\u88c5\u53ca\u914d\u7f6e<\/h2>\n<p>Dovecot\u5728\u672c\u4f8b\u4e2d\u5145\u5f53IMAP\u3001POP\u670d\u52a1\u5668\u7684\u89d2\u8272\uff0c\u540c\u65f6\u5b83\u4e5f\u5c06\u8d1f\u8d23\u7528\u6237\u767b\u5f55\u65f6\u7528\u6237\u8eab\u4efd\u7684\u9a8c\u8bc1\u300cDovecot\u4f1a\u5c06\u771f\u6b63\u7684\u9a8c\u8bc1\u5de5\u4f5c\u4ea4\u7ed9MySQL\u5904\u7406\u300d\u3002\u56e0\u4e3a\u4f7f\u7528SSL\uff0cDovecot\u5c06\u4f1a\u4f7f\u7528993\u300cIMAP\u534f\u8bae\u300d\u53ca995\u300cPOP\u534f\u8bae\u300d\u4e0e\u5916\u754c\u4ea4\u6d41\uff0c\u82e5\u670d\u52a1\u5668\u6709iptable\u4e4b\u7c7b\u7684\u73a9\u610f\u513f\uff0c\u8bf7\u5f00\u653e\u76f8\u5173\u7aef\u53e3\u3002<\/p>\n<p>\u8fd9\u90e8\u5206\u7684\u5185\u5bb9\u914d\u7f6e\u8d77\u6765\u76f8\u5bf9\u7b80\u5355\uff0c\u4f46\u662f\u9700\u8981\u914d\u7f6e\u7684\u6587\u4ef6\u7e41\u591a\u3002\u5927\u4f53\u4e0a\uff0c\u6211\u4eec\u9700\u8981\u914d\u7f6e\u5982\u4e0b\u7684\u4fe1\u606f\uff1a<\/p>\n<ol>\n<li>\u5f00\u542fDovecot\u7684IMAP\u3001POP3\u3001LMTP\u534f\u8bae<\/li>\n<li>\u544a\u77e5Dovecot\u672c\u5730\u90ae\u4ef6\u7684\u6295\u6863\u8def\u5f84<\/li>\n<li>\u8fde\u63a5Dovecot\u548cMySQL\u6570\u636e\u5e93\u4ee5\u9a8c\u8bc1\u7528\u6237\u8eab\u4efd<\/li>\n<li>\u914d\u7f6eSSL\u52a0\u5bc6\u76f8\u5173\u4fe1\u606f<\/li>\n<\/ol>\n<h3 id=\"articleHeader18\">Dovecot\u7684\u5b89\u88c5<\/h3>\n<p>\u901a\u8fc7\u5982\u4e0b\u547d\u4ee4\u5b89\u88c5Dovecot\u6700\u65b0\u7248\uff1a<\/p>\n<pre>apt-get install dovecot-core dovecot-imapd dovecot-pop3d dovecot-lmtpd dovecot-mysql<\/pre>\n<h3 id=\"articleHeader19\">Dovecot\u7684\u914d\u7f6e<\/h3>\n<p>\u9700\u8981\u4fee\u6539\u7684\u914d\u7f6e\u6587\u4ef6\u6709\uff1a<\/p>\n<ul>\n<li>\/etc\/dovecot\/dovecot.confDovecot\u7684\u4e3b\u914d\u7f6e\u6587\u4ef6<\/li>\n<li>\/etc\/dovecot\/conf.d\/10-mail.confDovecot\u5c06\u8981\u64cd\u4f5c\u7684\u78c1\u76d8\u8def\u5f84\u76f8\u5173\u914d\u7f6e\u4fe1\u606f<\/li>\n<li>\/etc\/dovecot\/conf.d\/10-auth.conf\u7528\u6237\u9a8c\u8bc1\u76f8\u5173\u914d\u7f6e\u4fe1\u606f<\/li>\n<li>\/etc\/dovecot\/conf.d\/auth-sql.conf.extSQL-Type\u9a8c\u8bc1\u76f8\u5173\u914d\u7f6e\u4fe1\u606f<\/li>\n<li>\/etc\/dovecot\/dovecot-sql.conf.extDovecot\u4e0e\u6570\u636e\u5e93\u8fde\u63a5\u76f8\u5173\u914d\u7f6e\u4fe1\u606f<\/li>\n<li>\/etc\/dovecot\/conf.d\/10-master.confDovecot\u672c\u5730socket\u76f8\u5173\u914d\u7f6e\u4fe1\u606f<\/li>\n<li>\/etc\/dovecot\/conf.d\/10-ssl.conf\u5173\u4e8eSSL\u7684\u76f8\u5173\u914d\u7f6e\u4fe1\u606f<\/li>\n<\/ul>\n<blockquote><p>\u8bf7\u6ce8\u610f\uff1a<br \/>\n\u5728\u4fee\u6539\u4e0a\u8ff0\u6587\u4ef6\u4e4b\u524d\uff0c\u8bf7\u4e00\u5b9a\u5148\u505a\u597d\u5907\u4efd\u4ee5\u65b9\u4fbf\u6062\u590d<\/p><\/blockquote>\n<h3 id=\"articleHeader20\">\u4fee\u6539\/etc\/dovecot\/dovecot.conf\u6587\u4ef6<\/h3>\n<p>\u4f7f\u7528vi\u7f16\u8f91\u5668\u6253\u5f00\/etc\/dovecot\/dovecot.conf\u6587\u4ef6\u5e76\u5728\u6587\u4ef6\u79cd\u52a0\u5165\u5982\u4e0b\u5185\u5bb9\uff1a<\/p>\n<pre>!include conf.d\/*.conf\r\n\r\n# Enable installed  \r\nprotocols!include_try \/usr\/share\/dovecot\/protocols.d\/*.protocol  \r\nprotocols = imap pop3 lmtp<\/pre>\n<p>\u5982\u679c\u4ee5\u4e0a\u5185\u5bb9\u5df2\u7ecf\u5b58\u5728\uff0c\u53ea\u9700\u8981\u628a\u8be5\u884c\u7684#\u53f7\u53bb\u6389\u5373\u53ef<br \/>\n\u4e0a\u8ff0\u5185\u5bb9\u5927\u81f4\u7684\u610f\u601d\u662f\uff1a\u544a\u8bc9Dovecot\u542f\u7528\u6240\u6709.conf\u6587\u4ef6\uff1b\u5e76\u5f00\u542fDovecot\u7684imap\u3001pop3\u3001lmtp\u7b49\u76f8\u5173\u534f\u8bae\u4f7f\u4e4b\u6b63\u5e38\u5de5\u4f5c<\/p>\n<h3 id=\"articleHeader21\">\u4fee\u6539\/etc\/dovecot\/conf.d\/10-mail.conf\u6587\u4ef6<\/h3>\n<p>\u6253\u5f00\u6587\u4ef6\u5e76\u627e\u5230mail_location\u76f8\u5173\u4fe1\u606f\uff0c\u5c06\u5176\u6307\u5b9a\u5230\u672c\u5730\u78c1\u76d8\u7684\u67d0\u4e2a\u8def\u5f84\uff0c\u8fd9\u4e2a\u8def\u5f84\u5c06\u6765\u4f1a\u5b58\u653e\u6536\u5230\u7684\u90ae\u4ef6\uff0c\u5982\u4e0b\u6240\u793a\uff1a<\/p>\n<pre>mail_location = maildir:\/var\/mail\/vhosts\/%d\/%n<\/pre>\n<p>\u540c\u65f6\uff0c\u627e\u5230\u6587\u4ef6\u4e2dmail_privileged_group\u76f8\u5173\u4fe1\u606f\u5e76\u5c06\u8d77\u4fee\u6539\u4e3a\uff1a<\/p>\n<pre>mail_privileged_group = mail<\/pre>\n<p>\u4fdd\u5b58\u6587\u4ef6\u5e76\u9000\u51fa<\/p>\n<p>\u5728\u547d\u4ee4\u884c\u79cd\u8f93\u5165\u5982\u4e0b\u5185\u5bb9\u4ee5\u67e5\u770b\/var\/mail\u8def\u5f84\u7684\u6743\u9650\uff1a<\/p>\n<pre>ls -ld \/var\/mail<\/pre>\n<p>\u663e\u793a\u7684\u5185\u5bb9\u5927\u81f4\u5e94\u8be5\u662f\uff1a<\/p>\n<pre>drwxrwsr-x 2 root mail 4096 May  11 15:08 \/var\/mail<\/pre>\n<p>\u521b\u5efa\/var\/mail\/vhosts\/\u6587\u4ef6\u5939\u7ed9\u6bcf\u4e2a\u9700\u8981\u542f\u7528\u7684\u57df\u540d\uff1a<\/p>\n<pre>mkdir -p \/var\/mail\/vhosts\/mydomain.com<\/pre>\n<p>\u8f93\u5165\u5982\u4e0b\u547d\u4ee4\u4ee5\u65b0\u5efavmail\u7528\u6237\u7ec4\u53ca\u7528\u6237\u5e76\u8d4b\u6743\u9650<\/p>\n<pre>groupadd -g 5000 vmail  \r\nuseradd -g vmail -u 5000 vmail -d \/var\/mail<\/pre>\n<p>\u63a5\u4e0b\u6765\u4fee\u6539\u4e00\u4e0b\/var\/mail\/\u76ee\u5f55\u7684\u6743\u9650\uff0c\u4f7fvmail\u80fd\u591f\u8bbf\u95ee\uff1a<\/p>\n<pre>chown -R vmail:vmail \/var\/mail<\/pre>\n<h3 id=\"articleHeader22\">\u4fee\u6539\/etc\/dovecot\/conf.d\/10-auth.conf\u6587\u4ef6<\/h3>\n<p>\u627e\u5230\u6587\u4ef6\u4e2ddisable_plaintext_auth\u5e76\u53d6\u6d88\u6ce8\u91ca<\/p>\n<pre>disable_plaintext_auth = yes<\/pre>\n<p>\u627e\u5230\u6587\u4ef6\u4e2dauth_mechanisms\u5e76\u5c06\u5176\u4fee\u6539\u4e3a\u5982\u4e0b\u503c\uff1a<\/p>\n<pre>auth_mechanisms = plain login<\/pre>\n<p>\u9ed8\u8ba4\u60c5\u51b5\u4e0b\uff0cDovecot\u662f\u5141\u8bb8Ubuntu\u7cfb\u7edf\u7528\u6237\u767b\u5f55\u4f7f\u7528\u7684\uff0c\u6211\u4eec\u9700\u8981\u5c06\u5176\u7981\u7528\u3002\u627e\u5230\u6587\u4ef6\u79cd\u5982\u4e0b\u5185\u5bb9\u5e76\u5c06\u5176\u6ce8\u91ca\uff1a<\/p>\n<pre>#!include auth-system.conf.ext<\/pre>\n<p>\u5f00\u542fDovecot\u7684MySQL\u652f\u6301\uff0c\u53d6\u6d88!include auth-sql.conf.ext\u7684\u6ce8\u91ca\u7b26\u53f7\uff1a<\/p>\n<pre>#!include auth-system.conf.ext  \r\n!include auth-sql.conf.ext  \r\n#!include auth-ldap.conf.ext  \r\n#!include auth-passwdfile.conf.ext  \r\n#!include auth-checkpassword.conf.ext  \r\n#!include auth-vpopmail.conf.ext  \r\n#!include auth-static.conf.ext<\/pre>\n<h3 id=\"articleHeader23\">\u4fee\u6539\/etc\/dovecot\/conf.d\/auth-sql.conf.ext\u6587\u4ef6<\/h3>\n<p>\u5728\u6587\u4ef6\u4e2d\u52a0\u5165\u5982\u4e0b\u5185\u5bb9\uff1a<\/p>\n<pre>passdb {  \r\n    driver = sql  \r\n    args = \/etc\/dovecot\/dovecot-sql.conf.ext  \r\n}  \r\n\r\nuserdb {  \r\n    driver = static  \r\n    args = uid=vmail gid=vmail home=\/var\/mail\/vhosts\/%d\/%n  \r\n}<\/pre>\n<h3 id=\"articleHeader24\">\u4fee\u6539\/etc\/dovecot\/dovecot-sql.conf.ext\u6587\u4ef6<\/h3>\n<p>\u53d6\u6d88\u6587\u4ef6\u4e2ddriver\u884c\u7684\u6ce8\u91ca\uff0c\u5e76\u5c06\u5176\u4fee\u6539\u4e3a\u5982\u4e0b\uff1a<\/p>\n<pre>driver = mysql<\/pre>\n<p>\u53d6\u6d88\u6587\u4ef6\u4e2dconnect\u884c\u7684\u6ce8\u91ca\uff0c\u5e76\u5c06\u5176\u4fee\u6539\u4e3a\u5982\u4e0b\uff1a<\/p>\n<pre>connect = host=127.0.0.1 dbname=mailserver user=mailserver password=mailserver123<\/pre>\n<p>\u53d6\u6d88\u6587\u4ef6\u4e2ddefault_pass_scheme\u884c\u7684\u6ce8\u91ca\uff0c\u5e76\u5c06\u5176\u4fee\u6539\u4e3a\u5982\u4e0b\uff1a<\/p>\n<pre>default_pass_scheme = SHA512-CRYPT<\/pre>\n<p>\u53d6\u6d88\u6587\u4ef6\u4e2dpassword_query\u884c\u7684\u6ce8\u91ca\uff0c\u5e76\u5c06\u8d77\u4fee\u6539\u4e3a\u5982\u4e0b\uff1a<\/p>\n<pre>password_query = SELECT email as user, password FROM virtual_users WHERE email='%u';<\/pre>\n<p>\u4fdd\u5b58\u9000\u51fa<\/p>\n<p>\u5728\u547d\u4ee4\u884c\u79cd\u8f93\u5165\u5982\u4e0b\u5185\u5bb9\u4ee5\u4fee\u6539\u76ee\u5f55\u6743\u9650\uff1a<\/p>\n<pre>chown -R vmail:dovecot \/etc\/dovecot\r\n\r\nchmod -R o-rwx \/etc\/dovecot<\/pre>\n<h3 id=\"articleHeader25\">\u4fee\u6539\/etc\/dovecot\/conf.d\/10-master.conf\u6587\u4ef6<\/h3>\n<p>\u6253\u5f00\u6587\u4ef6\u505a\u5982\u4e0b\u4fee\u6539\u300c\u901a\u8fc7\u5c06\u7aef\u53e3\u8bbe\u7f6e\u4e3a0\uff0c\u4ee5\u7981\u7528\u975eSSL\u52a0\u5bc6\u7684IMAP\u548cPOP3\u534f\u8bae\u300d\uff1a<\/p>\n<pre>service imap-login {  \r\n    inet_listener imap {  \r\n        port = 0   \r\n    }  \r\n    ...  \r\n}  \r\n\r\nservice pop3-login {  \r\n    inet_listener pop3 {  \r\n        port = 0  \r\n    }  \r\n    ...  \r\n}<\/pre>\n<p>\u627e\u5230\u6587\u4ef6\u4e2d\u7684service lmtp\u5e76\u5c06\u5176\u4fee\u6539\u5982\u4e0b\uff1a<\/p>\n<pre>service lmtp {  \r\n        unix_listener \/var\/spool\/postfix\/private\/dovecot-lmtp {  \r\n        mode = 0600  \r\n        user = postfix  \r\n        group = postfix  \r\n  }  \r\n\r\n  # Create inet listener only if you can't use the above UNIX socket  \r\n  #inet_listener lmtp {  \r\n        #Avoid making LMTP visible for the entire internet  \r\n        #address =  \r\n        #port =  \r\n        #}  \r\n }<\/pre>\n<p>\u627e\u5230\u6587\u4ef6\u4e2dservice auth\u5e76\u5c06\u5176\u5185\u5bb9\u4fee\u6539\u5982\u4e0b\uff1a<\/p>\n<pre>service auth {  \r\n    # auth_socket_path points to this userdb socket by default. It's typically  \r\n    # used by dovecot-lda, doveadm, possibly imap process, etc. Its default  \r\n    # permissions make it readable only by root, but you may need to relax these  \r\n    # permissions. Users that have access to this socket are able to get a list  \r\n    # of all usernames and get results of everyone's userdb lookups.  \r\n\r\n    unix_listener \/var\/spool\/postfix\/private\/auth {  \r\n            mode = 0666  \r\n            user = postfix  \r\n            group = postfix  \r\n    }  \r\n\r\n    unix_listener auth-userdb {  \r\n            mode = 0600  \r\n            user = vmail  \r\n            #group =  \r\n    }  \r\n\r\n    # Postfix smtp-auth  \r\n    #unix_listener \/var\/spool\/postfix\/private\/auth {  \r\n    #       mode = 0666  \r\n    #}  \r\n\r\n    # Auth process is run as this user.  \r\n    user = dovecot  \r\n}<\/pre>\n<p>\u627e\u5230\u6587\u4ef6\u4e2dservice auth-worker\u5185\u5bb9\u5e76\u4fee\u6539\u5982\u4e0b\uff1a<\/p>\n<pre>service auth-worker {  \r\n    # Auth worker process is run as root by default, so that it can access  \r\n    # \/etc\/shadow. If this isn't necessary, the user should be changed to  \r\n    # $default_internal_user.  \r\n\r\n    user = vmail  \r\n}<\/pre>\n<h3 id=\"articleHeader26\">\u4fee\u6539\/etc\/dovecot\/conf.d\/10-ssl.conf\u6587\u4ef6<\/h3>\n<p>\u627e\u5230\u6587\u4ef6\u4e2dssl_cert\u5e76\u4fee\u6539\u5185\u5bb9\u5982\u4e0b\u300c\u8bf7\u786e\u4fdddovecot\u7684pem\u6587\u4ef6\u5df2\u7ecf\u5b58\u5728\uff0c\u5982\u679c\u5927\u5bb6\u4f7f\u7528\u4e86\u81ea\u5df1\u7684SSL\u6587\u4ef6\uff0c\u8bf7\u5c06\u5982\u4e0b\u5185\u5bb9\u4fee\u6539\u4e3a\u76f8\u5e94\u7684\u8def\u5f84\u300d\uff1a<\/p>\n<pre>ssl_cert = &lt;\/etc\/dovecot\/dovecot.pem  \r\nssl_key = &lt;\/etc\/dovecot\/private\/dovecot.pem<\/pre>\n<p>\u5f3a\u5236\u7528\u6237\u4f7f\u7528SSL\u52a0\u5bc6\uff1a<\/p>\n<pre>ssl = required<\/pre>\n<p>\u91cd\u65b0\u542f\u52a8Dovecot\u670d\u52a1\uff1a<\/p>\n<pre>service dovecot restart<\/pre>\n<h2 id=\"articleHeader27\">\u6d4b\u8bd5\u90ae\u4ef6\u670d\u52a1\u5668\u662f\u5426\u6b63\u5e38<\/h2>\n<p>\u8bbe\u7f6e\u4e00\u4e2a\u5e10\u53f7\uff0c\u53ef\u4ee5\u5411MySQL\u5bf9\u5e94\u7684\u8868\u4e2d\u63d2\u5165\u6570\u636e\uff0c\u63a5\u4e0b\u6765\u4f7f\u7528\u90ae\u4ef6\u5ba2\u6237\u7aef\u6765\u6d4b\u8bd5\u4e00\u4e0b\u3002\u63a8\u8350\u4f7f\u7528Thunderbird\u90ae\u4ef6\u5ba2\u6237\u7aef\u6216\u8005Foxmail\u5ba2\u6237\u7aef\u7b49\u3002\u8bf7\u6ce8\u610f\u4ee5\u4e0b\u5185\u5bb9\uff1a<\/p>\n<ul>\n<li>\u90ae\u7bb1\u7684\u5168\u79f0\u300c\u5305\u62ec\u540e\u9762\u7684@mydomain.com\u300d\u5c06\u4f5c\u4e3a\u7528\u6237\u540d<\/li>\n<li>\u90ae\u7bb1\u5bc6\u7801\u662fMySQL\u6570\u636e\u5e93\u79cd\u5bf9\u5e94\u90ae\u7bb1\u7684\u5bc6\u7801<\/li>\n<li>\u670d\u52a1\u5668\u76f8\u5173\u63a5\u53e3\u662f\u5426\u5168\u90e8\u5f00\u653e\uff1f993\u3001995\u300125\u7b49<\/li>\n<li>\u90ae\u4ef6\u6536\u53d1\u7684\u6240\u6709\u534f\u8bae\uff0c\u5305\u62ecIMAP\u3001POP3\u3001SMTP\u5168\u90e8\u90fd\u9700\u8981\u5f00\u542fSSL\u52a0\u5bc6<\/li>\n<\/ul>\n<p>\u914d\u7f6e\u597d\u5ba2\u6237\u7aef\u4e4b\u540e\u5373\u53ef\u8fde\u63a5\u83b7\u53d6\u3001\u53d1\u9001\u90ae\u4ef6\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>&nbsp; MySQL\u5b89\u88c5\u53ca\u914d\u7f6e \u672c\u4f8b\u4e2d\u6211\u4eec\u4f7f\u7528MySQL\u6570\u636e\u5e93\u4fdd\u5b58Postfix\u9700\u8981\u670d\u52a1\u7684\u865a\u62df\u57df\u540d\u3001\u7528\u6237\u5e10\u53f7\u53ca\u5bc6\u7801\u3001\u90ae\u4ef6\u522b\u540d\u4e09\u4e2a\u91cd\u8981\u7684\u4fe1\u606f\u3002 \u8bf7\u6ce8\u610f\uff1a \u5176\u5b9ePostfix\u548cDovecot\u662f\u5b8c\u5168\u53ef\u4ee5\u4e0d\u4f7f\u7528\u6570\u636e\u5e93\u7684\uff0c\u4e8c\u8005\u90fd\u53ef\u4ee5\u901a\u8fc7\u5404\u79cd\u914d\u7f6e\u6587\u4ef6\u5b8c\u6210\u300c\u96f6\u6570\u636e\u5e93\u300d\u7684\u90ae\u4ef6\u670d\u52a1\u5668\u3002\u4f46\u662f\uff0c\u65e2\u7136\u53ef\u4ee5\u4f7f\u7528\u6570\u636e\u5e93\u8fd9\u4e48&hellip;<\/p>\n<p> <a class=\"more-link\" href=\"https:\/\/zhang.bo.de.com\/page\/2025\/01\/19\/48.html\">\u7ee7\u7eed\u9605\u8bfb<\/a><\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[],"class_list":{"0":"post-48","1":"post","2":"type-post","3":"status-publish","4":"format-standard","6":"category-article"},"_links":{"self":[{"href":"https:\/\/zhang.bo.de.com\/page\/wp-json\/wp\/v2\/posts\/48","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/zhang.bo.de.com\/page\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/zhang.bo.de.com\/page\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/zhang.bo.de.com\/page\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/zhang.bo.de.com\/page\/wp-json\/wp\/v2\/comments?post=48"}],"version-history":[{"count":1,"href":"https:\/\/zhang.bo.de.com\/page\/wp-json\/wp\/v2\/posts\/48\/revisions"}],"predecessor-version":[{"id":49,"href":"https:\/\/zhang.bo.de.com\/page\/wp-json\/wp\/v2\/posts\/48\/revisions\/49"}],"wp:attachment":[{"href":"https:\/\/zhang.bo.de.com\/page\/wp-json\/wp\/v2\/media?parent=48"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/zhang.bo.de.com\/page\/wp-json\/wp\/v2\/categories?post=48"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/zhang.bo.de.com\/page\/wp-json\/wp\/v2\/tags?post=48"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}