RainLoop je jednostavan, moderan i brz web-based klijent e-pošte. RainLoop izvorni kod se nalazi na Githubu . Ovaj vodič će vam pokazati kako instalirati RainLoop na novu instancu FreeBSD 12 Vultr.
Zahtjevi
- Web poslužitelj: Apache, Nginx, lighttpd ili drugi s podrškom za PHP. Koristimo Nginx.
- PHP verzija 5.4 i novije
- PHP proširenja:
cURL, iconv, json, libxml, dom, openssl, DateTime, PCRE,SPL
- Izborno: PDO (MySQL/PostgreSQL/SQLite) PHP proširenje (za kontakte)
Prije nego što počneš
Provjerite verziju FreeBSD-a.
uname -ro # FreeBSD 12.0-RELEASE
Provjerite je li vaš FreeBSD sustav ažuriran.
freebsd-update fetch install pkg update && pkg upgrade -y
Instalirajte potrebne pakete.
pkg install -y sudo vim unzip curl wget bash socat git
Izradite novi korisnički račun sa svojim željenim korisničkim imenom. Koristit ćemo johndoe.
adduser # Username: johndoe # Full name: John Doe # Uid (Leave empty for default): <Enter> # Login group [johndoe]: <Enter> # Login group is johndoe. Invite johndoe into other groups? []: wheel # Login class [default]: <Enter> # Shell (sh csh tcsh nologin) [sh]: bash # Home directory [/home/johndoe]: <Enter> # Home directory permissions (Leave empty for default): <Enter> # Use password-based authentication? [yes]: <Enter> # Use an empty password? (yes/no) [no]: <Enter> # Use a random password? (yes/no) [no]: <Enter> # Enter password: your_secure_password # Enter password again: your_secure_password # Lock out the account after creation? [no]: <Enter> # OK? (yes/no): yes # Add another user? (yes/no): no # Goodbye!
Pokrenite visudonaredbu i dekomentirajte %wheel ALL=(ALL) ALLredak kako biste omogućili članovima wheelgrupe da izvrše bilo koju naredbu.
visudo # Uncomment by removing hash (#) sign # %wheel ALL=(ALL) ALL
Sada se prebacite na svog novostvorenog korisnika pomoću su.
su - johndoe
NAPOMENA: Zamijenite johndoesvojim korisničkim imenom.
Postavite vremensku zonu.
sudo tzsetup
Instalirajte PHP i potrebna PHP proširenja
Instalirajte PHP, kao i potrebna PHP proširenja.
sudo pkg install -y php72 php72-mbstring php72-tokenizer php72-pdo php72-pdo_mysql php72-openssl php72-hash php72-json php72-phar php72-filter php72-zlib php72-dom php72-xml php72-xmlwriter php72-xmlreader php72-pecl-imagick php72-curl php72-session php72-ctype php72-iconv php72-gd php72-simplexml php72-zip php72-filter php72-tokenizer php72-calendar php72-fileinfo php72-intl php72-phar php72-soap php72-xmlrpc php72-opcache php72-mysqli php72-bcmath php72-gmp
Provjerite verziju.
php --version # PHP 7.2.19 (cli) (built: Jun 20 2019 01:25:01) ( NTS ) # Copyright (c) 1997-2018 The PHP Group # Zend Engine v3.2.0, Copyright (c) 1998-2018 Zend Technologies
Soft-link php.ini-productionna php.ini.
sudo ln -s /usr/local/etc/php.ini-production /usr/local/etc/php.ini
Omogućite i pokrenite PHP-FPM.
sudo sysrc php_fpm_enable=yes sudo service php-fpm start
Instalirajte MariaDB i kreirajte bazu podataka
Instalirajte MariaDB.
sudo pkg install -y mariadb102-client mariadb102-server
Provjerite verziju.
mysql --version # mysql Ver 15.1 Distrib 10.2.24-MariaDB, for FreeBSD12.0 (amd64) using readline 5.1
Pokrenite i omogućite MariaDB.
sudo sysrc mysql_enable="yes" sudo service mysql-server start
Pokrenite mysql_secure_installationskriptu da poboljšate sigurnost svoje MariaDB instalacije.
sudo mysql_secure_installation
Prijavite se u MariaDB kao root korisnik.
mysql -u root -p # Enter password:
Napravite novu MariaDB bazu podataka i korisnika. Zapamtite vjerodajnice za ovog novog korisnika.
CREATE DATABASE dbname; GRANT ALL ON dbname.* TO 'username' IDENTIFIED BY 'password'; FLUSH PRIVILEGES; exit;
Instalirajte i konfigurirajte Nginx
Instalirajte Nginx.
sudo pkg install -y nginx
Provjerite verziju.
nginx -v # nginx version: nginx/1.14.2
Omogućite i pokrenite Nginx.
sudo sysrc nginx_enable=yes sudo service nginx start
Pokrenite sudo vim /usr/local/etc/nginx/rainloop.confi postavite Nginx za Rainloop.
server { listen 80; listen [::]:80; server_name example.com; root /usr/local/www/rainloop; index index.php; location / { try_files $uri $uri/ /index.php?$query_string; } location ^~ /data { deny all; } location ~ \.php$ { try_files $uri =404; include fastcgi_params; fastcgi_index index.php; fastcgi_split_path_info ^(.+\.php)(.*)$; fastcgi_keep_conn on; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; fastcgi_pass 127.0.0.1:9000; } }
Spremite datoteku i izađite.
Sada moramo uključiti rainloop.confu glavnu nginx.confdatoteku.
Pokrenite sudo vim /usr/local/etc/nginx/nginx.confi dodajte sljedeći redak u http {}blok.
include rainloop.conf;
Testirajte konfiguraciju.
sudo nginx -t
Ponovno učitajte Nginx.
sudo service nginx reload
Instalirajte RainLoop
Napravite korijenski direktorij dokumenta.
sudo mkdir -p /usr/local/www/rainloop
Promijenite vlasništvo nad /usr/local/www/rainloopimenikom u johndoe.
sudo chown -R johndoe:johndoe /usr/local/www/rainloop
Preuzmite najnovije izdanje RainLoop-a i raspakirajte ga.
cd /usr/local/www/rainloop wget http://www.rainloop.net/repository/webmail/rainloop-latest.zip unzip rainloop-latest.zip -d /usr/local/www/rainloop rm rainloop-latest.zip
Promijenite vlasništvo nad /usr/local/www/rainloopimenikom u www.
sudo chown -R www:www /usr/local/www/rainloop
Idite do http://example.com/?adminu svom omiljenom pregledniku i prijavite se da biste konfigurirali RainLoop web-poštu. Zadano ime za prijavu je, admina lozinka je 12345.