Jump to content
Froxlor Forum
  • 1
irisdina

[Howto] Debian 9 | Ubuntu 17.10 + Froxlor + MariaDB + NGINX + PHP FPM + PHP7.1 + SSL

Question

Debian (9) Stretch

1

sudo apt install curl wget apt-transport-https dirmngr git

1a. Keys install

wget http://www.deb-multimedia.org/pool/main/d/deb-multimedia-keyring/deb-multimedia-keyring_2016.8.1_all.deb && dpkg -i deb-multimedia-keyring_2016.8.1_all.deb && wget https://nginx.org/keys/nginx_signing.key && apt-key add nginx_signing.key && curl https://packages.sury.org/php/apt.gpg | apt-key add -

1b. Source List ( nano /etc/apt/source.list )

Spoiler

 

###### Debian Main Repos
deb http://ftp.de.debian.org/debian/ stable main contrib non-free
deb-src http://ftp.de.debian.org/debian/ stable main contrib non-free
deb http://ftp.de.debian.org/debian/ stable-updates main contrib non-free
deb-src http://ftp.de.debian.org/debian/ stable-updates main contrib non-free
deb http://security.debian.org/ stable/updates main
deb-src http://security.debian.org/ stable/updates main
deb http://ftp.debian.org/debian stretch-backports main
deb-src http://ftp.debian.org/debian stretch-backports main

###### Extra Repos

###Debian Multimedia
deb [arch=i386,amd64] http://www.deb-multimedia.org stretch main non-free

###nginx
deb [arch=amd64,i386] http://nginx.org/packages/debian/ stretch nginx
deb-src [arch=amd64,i386] http://nginx.org/packages/debian/ stretch nginx

###php7.1 | curl https://packages.sury.org/php/apt.gpg | apt-key add -
deb https://packages.sury.org/php/ $(lsb_release -sc) main

 

1c. 

sudo apt update && sudo apt dist-upgrade && sudo apt autoclean && sudo apt autoremove

2.  MariaDB Install
use sudo command for install MariaDB!

sudo apt install mariadb-server mariadb-client

2a. MariaDB 10.1 Workround (Optional)

when you MariaDB install with not sudo command, have you Problems with your Froxlor install. 
you can use this workround: (Thanks J-BBB for this Note :) )

mysql -u root
MariaDB [(none)]> update mysql.user set password=password('your PASS') where user='root';
MariaDB [(none)]> update mysql.user set plugin='' where user='root';
MariaDB [(none)]> flush privileges;

3. nginx Install

sudo apt install nginx

3a

mkdir /etc/nginx/sites-available
mkdir /etc/nginx/sites-enabled

3b. nano /etc/nginx/nginx.conf

Spoiler

user www-data;
worker_processes auto;
pid /run/nginx.pid;
include /etc/nginx/modules-enabled/*.conf;

events {
    worker_connections 768;
    multi_accept on;
}

http {

    ##
    # Basic Settings
    ##

    sendfile on;
    tcp_nopush on;
    tcp_nodelay on;
    keepalive_timeout 65;
    server_tokens off;

    # server_names_hash_bucket_size 64;
    # server_name_in_redirect off;

    include /etc/nginx/mime.types;
        #include /etc/nginx/naxsi.rules;
        #include /etc/nginx/naxsi-wp.rules;
    default_type application/octet-stream;

    ##
    # SSL Settings
    ##

    ssl_protocols TLSv1 TLSv1.1 TLSv1.2; # Dropping SSLv3, ref: POODLE
    ssl_prefer_server_ciphers on;

    ##
    # Logging Settings
    ##

    access_log /var/log/nginx/access.log;
    error_log /var/log/nginx/error.log;

    ##
    # Gzip Settings
    ##

    gzip_vary on;
    gzip_proxied any;

    gzip_comp_level 6;
    gzip_buffers 16 8k;
    gzip_http_version 1.1;
    gzip_types text/plain text/css application/json application/x-javascript text/xml application/xml application/xml+rss text/javascript;

    ##
    # Virtual Host Configs
    ##

    include /etc/nginx/conf.d/*.conf;
    include /etc/nginx/sites-enabled/*;
}


#mail {
#    # See sample authentication script at:
#    # http://wiki.nginx.org/ImapAuthenticateWithApachePhpScript

#    # auth_http localhost/auth.php;
#    # pop3_capabilities "TOP" "USER";
#    # imap_capabilities "IMAP4rev1" "UIDPLUS";

#    server {
#        listen     localhost:110;
#        protocol   pop3;
#        proxy      on;
#    }

#    server {
#        listen     localhost:143;
#        protocol   imap;
#        proxy      on;
#    }
#}

3c. 

service nginx restart

4. PHP install

sudo apt update && sudo apt install php7.1-mysql php7.1-curl php7.1-gd php7.1-intl php-pear php-imagick php7.1-imap php7.1-mcrypt php-memcache php7.1-memcached php7.1-pspell php7.1-recode php7.1-sqlite3 php7.1-tidy php7.1-xmlrpc php7.1-xsl php7.1-mbstring php-gettext php7.1-fpm php7.1-cli php7.1-cgi php-bcmath php-zip

4a.

service nginx restart
service php7.1-fpm restart

 

Ubuntu 17.10 (Artful)

1

sudo apt install curl wget apt-transport-https dirmngr git software-properties-common python-software-properties

1b. Source List ( nano /etc/apt/source.list )

Spoiler

###### Ubuntu Main Repos
deb http://de.archive.ubuntu.com/ubuntu/ artful main restricted universe multiverse
deb-src http://de.archive.ubuntu.com/ubuntu/ artful main restricted universe multiverse

###### Ubuntu Update Repos
deb http://de.archive.ubuntu.com/ubuntu/ artful-security main restricted universe multiverse
deb http://de.archive.ubuntu.com/ubuntu/ artful-updates main restricted universe multiverse
deb http://de.archive.ubuntu.com/ubuntu/ artful-proposed main restricted universe multiverse
deb http://de.archive.ubuntu.com/ubuntu/ artful-backports main restricted universe multiverse
deb-src http://de.archive.ubuntu.com/ubuntu/ artful-security main restricted universe multiverse
deb-src http://de.archive.ubuntu.com/ubuntu/ artful-updates main restricted universe multiverse
deb-src http://de.archive.ubuntu.com/ubuntu/ artful-proposed main restricted universe multiverse
deb-src http://de.archive.ubuntu.com/ubuntu/ artful-backports main restricted universe multiverse

###### Ubuntu Partner Repo
deb http://archive.canonical.com/ubuntu artful partner
deb-src http://archive.canonical.com/ubuntu artful partner


###### 3rd Party Binary Repos

#### MariaDB 10.2 - sudo apt-key adv --recv-keys --keyserver hkp://keyserver.ubuntu.com:80 0xF1656F24C74CD1D8
deb [arch=amd64,i386] http://ftp.hosteurope.de/mirror/mariadb.org/repo/10.2/ubuntu zesty main
deb-src http://ftp.hosteurope.de/mirror/mariadb.org/repo/10.2/ubuntu zesty main

1c. Key Install

sudo apt-key adv --recv-keys --keyserver hkp://keyserver.ubuntu.com:80 0xF1656F24C74CD1D8

1d. PPA (https://askubuntu.com/questions/4983/what-are-ppas-and-how-do-i-use-them/4987#4987)

sudo add-apt-repository ppa:ondrej/nginx-mainline
sudo add-apt-repository ppa:ondrej/php

2. 

sudo apt update && sudo apt dist-upgrade && sudo apt autoclean && sudo apt autoremove

3.  MariaDB Install

sudo apt install mariadb-server mariadb-client

3a. MariaDB 10.1 Workround (Optional)

when you MariaDB install with not sudo command, have you Problems with your Froxlor install. 
you can use this workround: (Thanks J-BBB for this Note :) )

mysql -u root
MariaDB [(none)]> update mysql.user set password=password('your PASS') where user='root';
MariaDB [(none)]> update mysql.user set plugin='' where user='root';
MariaDB [(none)]> flush privileges;

4. nginx Install

sudo apt install nginx

4a. nano /etc/nginx/nginx.conf

Spoiler

user www-data;
worker_processes auto;
pid /run/nginx.pid;
include /etc/nginx/modules-enabled/*.conf;

events {
    worker_connections 768;
    multi_accept on;
}

http {

    ##
    # Basic Settings
    ##

    sendfile on;
    tcp_nopush on;
    tcp_nodelay on;
    keepalive_timeout 65;
    server_tokens off;

    # server_names_hash_bucket_size 64;
    # server_name_in_redirect off;

    include /etc/nginx/mime.types;
        #include /etc/nginx/naxsi.rules;
        #include /etc/nginx/naxsi-wp.rules;
    default_type application/octet-stream;

    ##
    # SSL Settings
    ##

    ssl_protocols TLSv1 TLSv1.1 TLSv1.2; # Dropping SSLv3, ref: POODLE
    ssl_prefer_server_ciphers on;

    ##
    # Logging Settings
    ##

    access_log /var/log/nginx/access.log;
    error_log /var/log/nginx/error.log;

    ##
    # Gzip Settings
    ##

    gzip_vary on;
    gzip_proxied any;

    gzip_comp_level 6;
    gzip_buffers 16 8k;
    gzip_http_version 1.1;
    gzip_types text/plain text/css application/json application/x-javascript text/xml application/xml application/xml+rss text/javascript;

    ##
    # Virtual Host Configs
    ##

    include /etc/nginx/conf.d/*.conf;
    include /etc/nginx/sites-enabled/*;
}


#mail {
#    # See sample authentication script at:
#    # http://wiki.nginx.org/ImapAuthenticateWithApachePhpScript

#    # auth_http localhost/auth.php;
#    # pop3_capabilities "TOP" "USER";
#    # imap_capabilities "IMAP4rev1" "UIDPLUS";

#    server {
#        listen     localhost:110;
#        protocol   pop3;
#        proxy      on;
#    }

#    server {
#        listen     localhost:143;
#        protocol   imap;
#        proxy      on;
#    }
#}

4b. 

service nginx restart

5. PHP install

sudo apt update && sudo apt install php7.1-mysql php7.1-curl php7.1-gd php7.1-intl php-pear php-imagick php7.1-imap php7.1-mcrypt php-memcache php7.1-memcached php7.1-pspell php7.1-recode php7.1-sqlite3 php7.1-tidy php7.1-xmlrpc php7.1-xsl php7.1-mbstring php-gettext php7.1-fpm php7.1-cli php7.1-cgi php-bcmath php-zip

5a.

service nginx restart
service php7.1-fpm restart

 

Froxlor Install Git version

1. vhost

nano /etc/nginx/sites-enabled/frox
Spoiler

server { 
    listen    your sub-domain:80 default;
    server_name    deine subdomain etc.;
    access_log      /var/log/nginx/access.log;
    root     /usr/share/nginx/;
    location / {
        index    index.php index.html index.htm;
    }
    
    location ~ \.php {
        fastcgi_split_path_info ^(.+\.php)(/.+)$;
        include fastcgi_params;
        include /etc/nginx/fastcgi_params;
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
        fastcgi_param PATH_INFO $fastcgi_path_info;
        try_files $fastcgi_script_name =404;
        fastcgi_pass unix:/run/php/php7.1-fpm.sock;
        fastcgi_index index.php;
    }
}

1a

service nginx restart

2. Change dir

cd /usr/share/nginx/

2a. Froxlor git Load

sudo git clone https://github.com/Froxlor/Froxlor.git

2a. Folder Rename

mv /usr/share/nginx/Froxlor /usr/share/nginx/your Folder Name

2b. User/Group Change for Froxlor Folder

sudo chown -HR www-data:www-data Your Froxlor Folder

3. Browser Open

http://your-SubDomain/your-Frolxor-Folder

3c. Change Your DB/User Name for Froxlor

1c4092bcfa.jpg

Install Froxlor finish

3d. Move userdata (Optional)

mv /tmp/userdata.inc.php /usr/share/nginx/Your Froxlor Folder/lib/

4. vhost delete

rm /etc/nginx/site-enable/frox

don't restart nginx!

Froxlor Settings

1. cronjob

nano /etc/cron.d/froxlor
#
# Set PATH, otherwise restart-scripts won't find start-stop-daemon
#
PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin
#
# Regular cron jobs for the froxlor package
#
# Please check that all following paths are correct
#
*/5 * * * *    root    /usr/bin/nice -n 5 /usr/bin/php -q /usr/share/nginx/your Froxlor Folder/scripts/froxlor_master_cronjob.php
chmod 0640 "/etc/cron.d/froxlor"
chown root:0 "/etc/cron.d/froxlor"
service cron restart

Froxlor Panel

1. Change your PHP-Backend Settings
Settings > Webserver settings > Nginx PHP backend

from 127.0.0.1:8888 to unix:/run/php/php7.1-fpm.sock

2. Make Folder and Change chmod

mkdir -p /etc/nginx/sites-enabled/
chown root:0 /etc/nginx/sites-enabled/
chmod 0600 /etc/nginx/sites-enabled/
mkdir -p /etc/nginx/sites-enabled/
chown root:0 /etc/nginx/sites-enabled/
chmod 0600 /etc/nginx/sites-enabled/
mkdir -p /home/customers/webs/
mkdir -p /var/customers/logs/
mkdir -p /var/customers/tmp
chmod 1777 /var/customers/tmp
service nginx restart

2a. IPs and Ports > Add IP/Port

5a0abb2923348_2port80.thumb.jpg.86aa85f5fed68b2be5781ccaa081ba6d.jpg

2a(1), SSL Port

ssl.thumb.jpg.392af0eefe69573a10e735efab4b2661.jpg

5a0abbfa454e0_sslport.thumb.JPG.984db8ea483048659d89b5b92884d19b.JPG

e0da66b243.jpg

Wait 5min for Autimatic Start Froxlor's cronjob

Optional

PHP-FPM activate

1. User/Group add

sudo adduser froxlorlocal --disabled-password --no-create-home

2. libnss-extrausers install

sudo apt install install nscd libnss-extrausers 
mkdir -p /var/lib/extrausers
touch /var/lib/extrausers/{passwd,group,shadow}
mv "/etc/nsswitch.conf" "/etc/nsswitch.conf.frx.bak"
nano /etc/nsswitch.conf
# Make sure that `passwd`, `group` and `shadow` have mysql in their lines
# You should place mysql at the end, so that it is queried after the other mechanisams
#
passwd:         compat extrausers
group:          compat extrausers
shadow:         compat extrausers

hosts:       files dns
networks:    files dns

services:    db files
protocols:   db files
rpc:         db files
ethers:      db files
netmasks:    files
netgroup:    files
bootparams:  files

automount:   files
aliases:     files
sudo service nscd restart
sudo nscd --invalidate=group

2a. Settings > System settings > Activate > Use libnss-extrausers instead of libnss-mysql

5a0ab9076514b_mysqllibnss.JPG.12412b89cfb570aacbb9ba20cc018632.JPG

3. Settings > PHP-FPM > Activated:
Change from NO to YES

3a. Settings > PHP-FPM > Settings
Change > Configuration directory of php-fpm to 

/etc/php/7.1/fpm/pool.d/

Change > php-fpm restart command to

/etc/init.d/php7.1-fpm restart or service php7.1-fpm restart

3b. Settings > Froxlor VirtualHost settings > Activate > Enable PHP-FPM for the Froxlor vHost

5a0ab9ad113be_froxlorfpm.JPG.f9851e4e1b4a69e51c530866f342a3be.JPG

3c. When you 502 error on Nginx have, use this command (Optional) (Thanks lino16 for this Note)

sudo usermod -a -G www-data froxlorlocal

SSL / Let's Encrypt activate

1. Create Folder on nginx

mkdir /etc/nginx/ssl
cd /etc/nginx/ssl

1a. Create SSL File

sudo openssl req -x509 -nodes -days 365 -newkey rsa:2048 -keyout /etc/nginx/ssl/nginx.key -out /etc/nginx/ssl/nginx.crt

1b. create acme.conf

nano /etc/nginx/acme.conf
location /.well-known/acme-challenge {
    alias /usr/share/nginx/Your Froxlor Folder/.well-known/acme-challenge;

    location ~ /.well-known/acme-challenge/(.*) {
        default_type text/plain;
    }
}

2. Open your  Froxlor Panel
Settings> SSL > Activated:
Change from NO to YES

2a. Settings > SSL > Settings
Change your path from your certificate / Keyfile

Path to the SSL certificate
insert

/etc/nginx/ssl/nginx.crt

Path to the SSL Keyfile
insert

/etc/nginx/ssl/nginx.key

2b. Settings > SSL > Settings
Activate > Enable Let's Encrypt

f1f454e31b.jpg

2c. Activate on Settings > Froxlor VirtualHost settings
- Enable Let's Encrypt for the froxlor vhost
- Enable SSL-redirect for the froxlor vhost
- HTTP Strict Transport Security (HSTS)
- Include HSTS for any subdomain
8bc097eda1.jpg

 

Share this post


Link to post
Share on other sites

18 answers to this question

Recommended Posts

  • 1

@irisdina: Danke für deine TOP Anleitung. Ich habe das Howto unter Ubuntu 17.10 (Artful) installiert.

Ich habe noch folgende Anmerkungen:

2a. MariaDB 10.1 Workround (Optional)  sollte nicht nur Debian, sondern auch Ubuntu 17.10 stehen, da ich dies auch brauchte.

PHP-FPM activate

2. libnss-extrausers install (hier fehlt apt)

sudo install nscd libnss-extrausers

Nach der Konfiguration von PHP-FPM nach der Anleitung kam immer der Gateway Fehler 502.

Das konnte ich mit folgendem Befehl lösen:

usermod -a -G www-data froxlorlocal

Share this post


Link to post
Share on other sites
  • 0
10 hours ago, J-B said:

Was spricht denn gegen die MariaDB von Debian Stretch?

seitens froxlor selbst nix :)

Share this post


Link to post
Share on other sites
  • 0
12 hours ago, J-B said:

Was spricht denn gegen die MariaDB von Debian Stretch?

In den Alten Versionen gab es ein Problem/Bug/Feature, dass man kein PW ändern konnte bzw. bei dem Install setzen konnte und später erst nervig ein PW einstellen konnte.

 

2 hours ago, d00p said:

seitens froxlor selbst nix :)

will man doch hoffen, das Froxlor nichts dagegen hat :P

Share this post


Link to post
Share on other sites
  • 0

Wenn man den Standard MariaDB Server benutzen will von Debian 9, muss man das unix_socket Plugin deaktivieren.

 

Wie das geht wird hier beschrieben.

Share this post


Link to post
Share on other sites
  • 0

Du benutzt in deiner Anleitung ja PHP-FPM.

Dies braucht aber doch (laut alter Anleitung) das Paket "libnss-mysql", welches es unter Debian 9 Stretch nicht mehr gibt.

Wird dieses nicht mehr benötigt, oder warum wird es hier nicht erwähnt? 

Share this post


Link to post
Share on other sites
  • 0
21 hours ago, Infected said:

Dies braucht aber doch (laut alter Anleitung) das Paket "libnss-mysql", welches es unter Debian 9 Stretch nicht mehr gibt.

Wird dieses nicht mehr benötigt, oder warum wird es hier nicht erwähnt? 

Das ist seit debian 8 nicht mehr bei debian dabei. Nutze am besten für debian 8 und 9 libnss-extrausers, dafür auch in froxlor den support aktivieren in den einstellungen

Share this post


Link to post
Share on other sites
  • 0

Guten Tag,

 

Ich habe es nach der Anleitung oben durch geführt.

Bis zum letzten schritt bis auf die Sache mit acme.con das wollte ich erst danach machen.

Doch eine neue vhost datei hat mir Froxlor nicht angelegt.

oder dauert das einen Moment bis das durch läuft?

Share this post


Link to post
Share on other sites
  • 0
2 hours ago, htmljucky said:

oder dauert das einen Moment bis das durch läuft?

Standardmäßig läuft der cronjob alle 5 Minuten

Share this post


Link to post
Share on other sites
  • 0

Okay und wie muss ich das mit lets crypt einrichten?
Finde dazu leider auch nichts

 


Edit:

Habe nun gewartet aber keine Änderung das er einen nginx Eintrag selbst schreibt.

Share this post


Link to post
Share on other sites
  • 0

hä? Wie wie muss ich das einrichten? Du aktivierst Let's Encrypt in den Einstellungen (global), du musst natürlich die acme.conf einrichten (konfiguration -> webserver) damit der globale Alias existiert und Ende. das wars. Entsprechend musst du natürlich auch einer SSL-enabled domain noch sagen, sie soll let's encrypt nutzen (domain -> bearbeiten)

Share this post


Link to post
Share on other sites
  • 0
11 hours ago, lino16 said:

@irisdina: Danke für deine TOP Anleitung. Ich habe das Howto unter Ubuntu 17.10 (Artful) installiert.

Ich habe noch folgende Anmerkungen:

2a. MariaDB 10.1 Workround (Optional)  sollte nicht nur Debian, sondern auch Ubuntu 17.10 stehen, da ich dies auch brauchte.

PHP-FPM activate

2. libnss-extrausers install (hier fehlt apt)


sudo install nscd libnss-extrausers

Nach der Konfiguration von PHP-FPM nach der Anleitung kam immer der Gateway Fehler 502.

Das konnte ich mit folgendem Befehl lösen:

usermod -a -G www-data froxlorlocal

Wenn du es zu 100% nach dem Howto gemacht hast, sollte dies nicht auftreten mit MariaDB, da bei der Ubu Anleitung die 10.2 drin ist.
Das mit dem error 502 passiert eigentlich nur, wenn man vergisst den Froxlor ordner die rechte vorher von www-data zu geben, dann passiert dies.

Habe die zwei anmerkungen ins Howto aufgenommen, danke.

Share this post


Link to post
Share on other sites
  • 0

Danke für das Klasse Tutorial !!!

Bei mir hat alles geklappt.

Eine Anmerkung, ich musste nach der Installation noch folgenden Eintrag bei den Froxlor EInstellungen machen, sonst gingen meine vHost Container nicht (siehe Bild).

Ich habe auch den 502 Fehler bekommen, das lag bei mir daran das im Verzeichnis

/etc/php/7.1/fpm/pool.d/

keine Datei angelegt war, deshalb kam mein php-fpm nicht hoch. Ich habe dann die Konfig so geändert das der php-fpm kurz starten konnte, dann es wieder umgestellt wie im Tutorial und dann erst konnte Froxlor die Datei anlegen ( also php Datei für den Froxlor vHost ) und dann kam der php-fpm wieder hoch.

Bei Ubuntu 17.10 musste ich nginx und php-fpm noch in den Autostart reinnehmen, die kamen nach Installation nicht automatisch hoch.

 

Und bei

2a(1), SSL Port

wäre noch zu sagen, dass man vorher in den Einstellungen "SSL Aktivieren" anklicken muss, sonst kann man den SSL Port nicht anlegen.

 

Ansonsten geiles Tutorial, bitte in die aktuelle Froxlor Installation mit aufnehmen. Die unterscheidet sich ja doch etwas von der im Backend.

vhost.PNG

Share this post


Link to post
Share on other sites
  • 0

One more thing.

I had the Problem that I had to disable the mysql Strict Mode.

Otherwise I had the error

SQLSTATE[HY000]: General error: 1364 Field 'mail_virtual' doesn't have a default value

Everytime I wanted to delete a Domain.

I did it with the following Instruction:

https://serverpilot.io/community/articles/how-to-disable-strict-mode-in-mysql-5-7.html

After that I created the table with:

ysql> CREATE TABLE `mail_virtual` (
    ->   `id` int(11) NOT NULL auto_increment,
    ->   `email` varchar(255) NOT NULL default '',
    ->   `email_full` varchar(255) NOT NULL default '',
    ->   `destination` text NOT NULL default '',
    ->   `domainid` int(11) NOT NULL default '0',
    ->   `customerid` int(11) NOT NULL default '0',
    ->   `popaccountid` int(11) NOT NULL default '0',
    ->   `iscatchall` tinyint(1) unsigned NOT NULL default '0',
    ->   PRIMARY KEY  (`id`),
    ->   KEY `email` (`email`)
    -> ) ENGINE=MyISAM CHARSET=utf8 COLLATE=utf8_general_ci;

 

Share this post


Link to post
Share on other sites
  • 0
11 hours ago, j4mb4l4j4 said:

I had to disable the mysql Strict Mode

Try current git Version

Share this post


Link to post
Share on other sites
  • 0

Hi Danke dir für die Antwort,

die habe ich allerdings am Sonntag benutzt bei der Installation.
Und nach der Installation war die TABLE nicht da.

Hattest du jüngst ein Update gemacht ?

Nutze Ubuntu 17.10 und die neueste mysql-server dazu.

 

Ich habe auch nach der Installation das Problem mit Letsencrypt, das ich nicht auf die Datei ( zum testen wie du in vielen Beiträgen hier empfohlen hast ) ( oder neuen Forumsbeitrag dazu aufmachen ? )

Suche mich da seit 14 Stunden wund :-) :

/var/www/cust01.DOMAIN.com/.well-known/acme-challenge/test.html

Zugreifen kann, damit Letsencrypt geht.

Wenn ich darauf zugreife schreibt der nginx laut error.log immer:

2017/12/12 15:21:34 [error] 12563#12563: *27 open() "/var/www.cust01.DOMAIN.com/.well-known/acme-challenge/test.html" failed (2: No such file or directory), client: 31.16.227.7, server: cust01.DOMAIN.com, request: "GET /.well-known/acme-challenge/test.html HTTP/2.0", host: "cust01.DOMAIN.com"

Weißt du woran das liegt das es so komisch umgeschrieben wird , also der "/" statt des "." geschrieben wird ?

Meine /etc/nginx/acme.conf ist gemäß Tutorial:

location /.well-known/acme-challenge {
        alias /var/www/cust01.DOMAIN.com/.well-known/acme-challenge;

        location ~ /.well-known/acme-challenge/(.*) {
                default_type text/plain;
        }
}

Wenn ich test.html in das Verzeichnis

/var/www/cust01.DOMAIN.com/.well-known/test.html

lege, funktioniert der Aufruf der Datei.

Das ist das einzige was mich nach der Installationsanleitung grade noch am Betrieb hindert.

Die SSL Zerts sind laut Doku von oben auch nur bei folgendem hinterlegt ( siehe Bild ).
Mit IP/Ports kam aber trotzdem der Umschreibefehler wenn ich das Zertifikat dort angegeben habe.

PS: Vhost von 80 und 443 sind:

        listen    93.104.212.200:80 default_server;
        # Froxlor default vhost
        server_name    cust01.DOMAIN.com;
        access_log      /var/log/nginx/access.log;
        include /etc/nginx/acme.conf;
# temp. disabled ssl-redirect due to Let's Encrypt certificate generation.
        root     /var/www/cust01.DOMAIN.com/;
        index    index.php index.html index.htm;

        location / {
        }
return 301 https://$host$request_uri;
        location ~ \.php {
                fastcgi_split_path_info ^(.+\.php)(/.+)$;
                include /etc/nginx/fastcgi_params;
                fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
                fastcgi_param PATH_INFO $fastcgi_path_info;
                try_files $fastcgi_script_name =404;
                fastcgi_pass unix:/var/run/froxlor.panel-cust01.DOMAIN.com-php-fpm.socket;
                fastcgi_index index.php;
        }
}
# Created 12.12.2017 15:15
# Do NOT manually edit this file, all changes will be deleted after the next domain change at the panel.

server {
        listen    93.104.212.200:443 default_server ssl http2;
        # Froxlor default vhost
        server_name    cust01.DOMAIN.com;
        access_log      /var/log/nginx/access.log;
        include /etc/nginx/acme.conf;
        root     /var/www/cust01.DOMAIN.com/;
        index    index.php index.html index.htm;

        location / {
        }
        ssl_protocols TLSv1 TLSv1.2;
        ssl_ciphers ECDH+AESGCM:ECDH+AES256:!aNULL:!MD5:!DSS:!DH:!AES128;
        ssl_ecdh_curve secp384r1;
        ssl_prefer_server_ciphers on;
        ssl_certificate /etc/letsencrypt/live/cust01.DOMAIN.com/fullchain.pem;
        ssl_certificate_key /etc/letsencrypt/live/cust01.DOMAIN.com/privkey.pem;
        location ~ \.php {
                fastcgi_split_path_info ^(.+\.php)(/.+)$;
                include /etc/nginx/fastcgi_params;
                fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
                fastcgi_param PATH_INFO $fastcgi_path_info;
                try_files $fastcgi_script_name =404;
                fastcgi_param HTTPS on;
                fastcgi_pass unix:/var/run/froxlor.panel-cust01.DOMAIN.com-php-fpm.socket;
                fastcgi_index index.php;
        }
}


 

ssl-cert.PNG

ssl-cert-2.PNG

Share this post


Link to post
Share on other sites
  • 0

UPDATE:
Hab den Fehler gefunden, das Verzeichnis

/var/www/cust01.DOMAIN.com/.well-known/acme-challenge

Hatte die Rechte

drwxr-xr-x  2 froxlorlocal froxlorlocal 4096 Dec 12 16:08 acme-challenge

Ich habe dann die Rechte

drwxr-xr-x  2 www-data www-data 4096 Dec 12 16:08 acme-challenge

gesetzt und konnte die Datei aufrufen.

Jetzt hat Froxlor es wieder zu

drwxr-xr-x  2 froxlorlocal froxlorlocal 4096 Dec 12 16:08 acme-challenge

gemacht, aber ich kann es jetzt ohne Probleme aufrufen.

Jetzt klappts auch wieder mit dem nachbarn.

 

Einziges letztes Problem ist, das Letsencrypt sich gerade nicht automatisch Cronjobed. Muss es noch manuell anstoßen, vllt liegts daran das ich das Zertifikat nicht bei IP/Ports habe

 

UPDATE 2:

Der Cron war nicht eingetragen, vieleicht weil Letsencrypt nicht funktioniert hatte zuvor.
Jetzt funktioniert es. Das mit dem Verzeichnisrecht ist mir allerdings immernoch ein Rätsel.

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now


  • Similar Content

    • By H4nSolo
      Hallo Liebe Froxlor Community,
       
      derzeitig beschäftige ich mich mit einem sehr koriosen Problem was mich, je länger ich damit zu kämpfen habe, zur Weisglut bringt.
      Aktuell benutze ich die letzte Froxlor Github Version und muss mich permanent neu einloggen.
      Dabei spielt es keine Rolle ob ich mich als Admin oder Kunde anmelde.
      Der automatische Logout kommt nach einer unbestimmten Zeit und egal welcher Aktion

      Beispiel Ablauf:
      - Logge mich als Admin ein
      - Bearbeite die Domains
      - Werde gewzungen mich neu anzumelden und  vorherige eingegebene Daten sind verschwunden bzw nicht gesichert worden
      - Logge mich erneut ein
      - Wähle Kundenverwaltung
      - Klicke auf Kunde
      - Werde gewzungen mich neu anzumelden...

      Ja ich habe schon die Sessiontime für die Logins erhöht und weitere einstllungen probiert, jedoch ist dies nicht mein Fehler bzw ändern nichts an dem permanenten wiederanmelden.
      Ich habe auch schon in den Webserver logs nach Fehlern geschaut aber da wird sowohl in den access als auch im Error Log keinerlei Fehlemeldung angezeigt.
      Bei mir spielt es ausserdem auch keine Rolle welche Browser ich benutze da bei allen (sowohl aktuellster FireFox als auch Chrome / Opera Browser) das selbe Phenonem auftritt.

      Daten:
      Root: OVH Dedicated Root (4kerne, 64gb Ram 2TB HHD)
      OS: Ubuntu 16.04 LTS
      Webserver: apache2 (version 2.4)
       
      Ich hoffe das ihr mir weiterhelfen könnt.

      Sollte ich etwas an Informationen vergessen haben, bitte bescheid geben.


      lg H4nSolo
    • By LuckySparkle
      Einen wunderschönen guten Abend,
      Ich habe ein kleines Problem mit Subdomains auf meinem Webserver. Ich habe für diesen Froxlor mit LetsEncrypt eingestellt und bereits RainLoop als Webmailer eingerichtet. Das hat wunderbar funktioniert über 
      meinedomain.de/webmailordner.
      Nun wollte ich allerdings eine Subdomain anlegen (webmail.meinedomain.de) das will aber nicht funktionieren. Die Subdomain bekommt korrekt ein SSL Zertifikat zugewiesen, allerdings wird die in dem Verzeichnis liegende PHP Datei nicht ausgeführt sondern einfach nur der Inhalt angezeigt. Somit ist das Aufrufen des Webmailers nicht möglich. Rufe ich den Webmailer wieder über "meinedomain.de/webmailordner" auf funktioniert alles ganz normal.
      Ebenfalls wollte ich das Verzeichnis von meinedomain.de ändern, sobald ich das allerdings mache bekomme ich nur noch den Fehler 403 forbidden unter der Domain. Sobald ich den Pfad wieder in den Kundenroot ändere funktioniert es wieder. 
      Allerdings sollen auf den Server doch diverse Domains für verschiedene Dienste umgezogen werden und die aktuelle Domain ist nur für einen Dienst gedacht soll also auf einen Unterordner verweisen, wo ist hier das Problem?
      Vielen Dank für eure Hilfe! In den angehängten Screenshot ist die Konfiguration in Froxlor zu sehen, falls noch etwas benötigt wird reiche ich das natürlich sofort nach. 



    • By Developer
      Hallo zusammen,
      ich habe ein Problem mit Froxlor, bzw. dessen Erreichbarkeit. Ich habe auf meinem Root-Server Debian 8.9 (Jessie) laufen und dort Froxlor installiert. Froxlor liegt in /var/www/froxlor/. Problem ist nun, dass diese Adresse von meinem Apache anscheinend nie abgerufen wird. Der Server-Name domain1.de und noch eine weitere Domain domain2.de die beide ihre eigenen Customers in /var/customers/webs/ haben funktionieren problemlos. Als Workaround habe ich versucht /var/www/froxlor in das webs Verzeichnis eines Customers zu symlinken, dann bekomme ich allerdings folgenden php-Error:
      [Wed Nov 29 10:47:43.392017 2017] [:error] [pid 8404] [client xxxxx:44863] PHP Warning: Unknown: open_basedir restriction in effect. File(/var/www/froxlor/index.php) is not within the allowed path(s): (/var/customers/webs/johannes:/tmp) in Unknown on line 0 [Wed Nov 29 10:47:43.392110 2017] [:error] [pid 8404] [client xxxxx:44863] PHP Warning: Unknown: failed to open stream: Operation not permitted in Unknown on line 0 [Wed Nov 29 10:47:43.392127 2017] [:error] [pid 8404] [client xxxxx:44863] PHP Fatal error: Unknown: Failed opening required '/var/customers/webs/johannes/froxlor/index.php' (include_path='.:/usr/share/php:/usr/share/pear') in Unknown on line 0 Ich habe außerdem festgestellt, dass die beiden vhosts 10_froxlor_ipandport_x.x.x.x.433.conf und 10_froxlor_ipandport_x.x.x.x.80.conf komplett leer von froxlor erzeugt werden. Nur der Header ist drin:
      # 10_froxlor_ipandport_x.x.x.x.443.conf # Created 28.11.2017 16:55 # Do NOT manually edit this file, all changes will be deleted after the next domain change at the panel. Also kann mir jedemand hier helfen, wie ich froxlor wieder erreichbar machen kann?
      Viele Grüße und schonmal vielen Dank,
      Johannes
    • By UncleSnycs
      Hallo ich hoffe, mir kann jemand helfen. Ich habe eine Subdomain erstellt (phpmyadmin.example.ltd). Dort funktioniert PHP ohne probleme. Auf meiner anderen Subdomain (wi.example.ltd) funktioniert PHP überhaupt nicht und er zeigt mir bei der index.php nur den text an, der in der Datei drin steht. In Der vHost.conf steht, dass php disabled ist. Weiss jemand, wo man das aktivieren kann? Ich finde in der Konfiguration von der Subdomain den Eintrag nicht.
      Vielen Dank schonmal in vorraus.
      Mit freundlichen Grüßen
      UncleSnycs


×