25개 이상의 토픽을 선택하실 수 없습니다. Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

README.md 4.4 KiB

5 년 전
5 년 전
5 년 전
5 년 전
5 년 전
5 년 전
5 년 전
5 년 전
5 년 전
4 년 전
4 년 전
5 년 전
5 년 전
5 년 전
5 년 전
5 년 전
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. # Email server setup script
  2. I wrote this script during the gruelling process of installing and setting up
  3. an email server. It perfectly reproduces my successful steps to ensure the
  4. same setup time and time again.
  5. I've linked this file on Github to a shorter, more memorable address on my
  6. website so you can get it on your machine with this short command:
  7. ```
  8. curl -LO lukesmith.xyz/emailwiz.sh
  9. ```
  10. When prompted by a dialog menu at the beginning, select "Internet Site", then
  11. give your full domain without any subdomain, i.e. `lukesmith.xyz`.
  12. Read this readme and peruse the script's comments before running it. Expect it
  13. to fail and you have to do bug testing and you will be very happy when it
  14. actually works perfectly.
  15. ## This script installs
  16. - **Postfix** to send mail.
  17. - **Dovecot** to receive mail.
  18. - Config files that unique the two above securely with native log-ins.
  19. - **Spamassassin** to prevent spam and allow you to make custom filters.
  20. - **OpenDKIM** to validate you so you can send to Gmail and other big sites.
  21. ## This script does _not_
  22. - use a SQL database or anything like that.
  23. - set up a graphical interface for mail like Roundcube or Squirrel Mail. If you
  24. want that, you'll have to install it yourself. I just use
  25. [isync/msmtp/mutt-wizard](https://github.com/lukesmithxyz/mutt-wizard) to
  26. have an offline mirror of my email setup and I recommend the same. There are
  27. other ways of doing it though, like Thunderbird, etc.
  28. ## Requirements
  29. 1. A **Debian or Ubuntu server**. I've tested this on a
  30. [Vultr](https://www.vultr.com/?ref=8384069-6G) Debian server and one running
  31. Ubuntu and their setup works, but I suspect other VPS hosts will have
  32. similar/possibly identical default settings which will let you run this on
  33. them. Note that the affiliate link there to Vultr gives you a $100 credit
  34. for the first month to play around.
  35. 2. **A Let's Encrypt SSL certificate for your site's `mail.` subdomain**.
  36. Create a nginx/apache site at `mail.<yourdomain.com>` and get a certificate
  37. for it with Let's Encrypt's [Certbot](https://certbot.eff.org/).
  38. 3. You need two little DNS records set on your domain registrar's site/DNS
  39. server: (1) an **MX record** pointing to your own main domain/IP and (2) a
  40. **CNAME record** for your `mail.` subdomain.
  41. 4. `apt purge` all your previous (failed) attempts to install and configure a
  42. mailserver. Get rid of _all_ your system settings for Postfix, Dovecot,
  43. OpenDKIM and everything else. This script builds off of a fresh install.
  44. 5. Some VPS providers block port 25 (used to send mail). You may need to
  45. request that this port be opened to send mail successfully. Although I have
  46. never had to do this on a Vultr VPS, others have had this issue so if you
  47. cannot send, contact your VPS provider.
  48. ## Post-install requirement!
  49. - After the script runs, you'll have to add two *additional DNS TXT records*
  50. which involves the OpenDKIM key that it generates during the script.
  51. ## Making new users/mail accounts
  52. Let's say we want to add a user Billy and let him receive mail, run this:
  53. ```
  54. useradd -m -G mail billy
  55. passwd billy
  56. ```
  57. Any user added to the `mail` group will be able to receive mail. Suppose a user
  58. Cassie already exists and we want to let her receive mail to. Just run:
  59. ```
  60. usermod -a -G mail cassie
  61. ```
  62. A user's mail will appear in `~/.Mail/`. I you want to see your mail while
  63. ssh'd in the server, you could just install mutt, add `set spoolfile="+Inbox"`
  64. to your `~/.muttrc` and use mutt to view and reply to mail. You'll probably
  65. want to log in remotely though:
  66. ## Logging in from Thunderbird or mutt (and others) remotely
  67. Let's say you want to access your mail with Thunderbird or mutt or another
  68. email program. For my domain, the server information will be as follows:
  69. - SMTP server: `mail.lukesmith.xyz`
  70. - SMTP port: 587
  71. - IMAP server: `mail.lukesmith.xyz`
  72. - IMAP port: 993
  73. - Username `luke` (I.e. *not* `luke@lukesmith.xyz`)
  74. The last point is important. Many email systems use a full email address on
  75. login. Since we just simply use local PAM logins, only the user's name is used
  76. (this makes a difference if you're using my
  77. [mutt-wizard](https://github.com/lukesmithxyz/mutt-wizard), etc.).
  78. ## Tweaking things
  79. You're a big boy now if you have your own mail server!
  80. You can tweak Postfix (sending mail
  81. ## Benefited from this?
  82. If this script or documentation has saved you some frustration, you can donate
  83. to support me at [lukesmith.xyz/donate](https://lukesmith.xyz/donate.html).