FreeBSD10+Nginx1.4.4+PHP5.5.9+MySQL5.6.15

netkiller發表於2016-05-14

1. PHP 5.5.9

文字格式回覆

cd /usr/ports/lang/php55
make install clean; rehash
		

開啟下面三個 PHP 編譯選項

		
[X] CLI        Build CLI version
[X] CGI        Build CGI version
[X] FPM        Build FPM version (experimental)
		
		

FreeBSD啟動是自動開啟php-fpm服務

		
cat >> /etc/rc.conf <<EOF
php_fpm_enable="YES"
EOF
		
		

安裝PHP擴充套件

cd /usr/ports/lang/php55-extensions
make install clean; rehash
		

FPM啟動指令碼

# /usr/local/etc/rc.d/php-fpm start
		

2. MySQL 5.6.15

安裝 MySQL server 與 client

		
pkg install mysql56-server
pkg install mysql56-client
		
		

設定mysql root密碼

/usr/local/etc/rc.d/mysql-server onestart
/usr/local/bin/mysqladmin -u root password `newpassword`
		

FreeBSD 啟動時開啟MySQL服務

		
cat >> /etc/rc.conf <<EOF
mysql_enable="YES"
EOF
		
		

MySQL 啟動指令碼

# /usr/local/etc/rc.d/mysql-server
		

3. Nginx 1.4.4

所特殊需求,所以採用pkg安裝

# pkg install nginx
		

如果需要特別編譯模組可以使用ports安裝

cd /usr/ports/www/nginx
make install clean; rehash
		

服務開啟

		
cat >> /etc/rc.conf <<EOF
nginx_enable="YES"
EOF
		
		

Nginx 啟動指令碼的位置

# /usr/local/etc/rc.d/nginx start
		

例 1. Nginx 配置檔案

/usr/local/etc/nginx/nginx.conf

#user  nobody;
worker_processes  1;

#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;

#pid        logs/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include       mime.types;
    default_type  application/octet-stream;

    #log_format  main  `$remote_addr - $remote_user [$time_local] "$request" `
    #                  `$status $body_bytes_sent "$http_referer" `
    #                  `"$http_user_agent" "$http_x_forwarded_for"`;

    #access_log  logs/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    #keepalive_timeout  0;
    keepalive_timeout  65;

    gzip  on;

	include /usr/local/etc/nginx/conf.d/*.conf;

}
			

/usr/local/etc/nginx/conf.d/host.domain.conf

server {
    listen       80;
    server_name  localhost;

    #charset koi8-r;

    #access_log  logs/host.access.log  main;

    location / {
        root   /usr/local/www/nginx;
        index  index.html index.php;
    }

    #error_page  404              /404.html;

    # redirect server error pages to the static page /50x.html
    #
    error_page   500 502 503 504  /50x.html;
    location = /50x.html {
        root   /usr/local/www/nginx-dist;
    }

    # proxy the PHP scripts to Apache listening on 127.0.0.1:80
    #
    #location ~ .php$ {
    #    proxy_pass   http://127.0.0.1;
    #}

    # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
    #
    location ~ .php$ {
        root           html;
        fastcgi_pass   127.0.0.1:9000;
        fastcgi_index  index.php;
        fastcgi_param  SCRIPT_FILENAME  /usr/local/www/nginx$fastcgi_script_name;
        include        fastcgi_params;
    }

    # deny access to .htaccess files, if Apache`s document root
    # concurs with nginx`s one
    #
    #location ~ /.ht {
    #    deny  all;
    #}
}


# another virtual host using mix of IP-, name-, and port-based configuration
#
#server {
#    listen       8000;
#    listen       somename:8080;
#    server_name  somename  alias  another.alias;

#    location / {
#        root   html;
#        index  index.html index.htm;
#    }
#}


# HTTPS server
#
#server {
#    listen       443;
#    server_name  localhost;

#    ssl                  on;
#    ssl_certificate      cert.pem;
#    ssl_certificate_key  cert.key;

#    ssl_session_timeout  5m;

#    ssl_protocols  SSLv2 SSLv3 TLSv1;
#    ssl_ciphers  HIGH:!aNULL:!MD5;
#    ssl_prefer_server_ciphers   on;

#    location / {
#        root   html;
#        index  index.html index.htm;
#    }
#}