FreeBSD 10 + Nginx 1.4.4 + PHP 5.5.9 + MySQL 5.6.1

FreeBSD 10 + Nginx 1.4.4 + PHP 5.5.9 + MySQL 5.6.15

How to Install Nginx and PHP-FPM on FreeBSD 10

MrNeo Chen (netkiller)陳景峯(BG7NYT)


中國廣東省深圳市龍華新區民治街道溪山美地
518131
+86 13113668890
+86 755 29812080
<netkiller@msn.com> php

$Id$ html

版權 © 2011, 2012, 2013, 2014 http://netkiller.github.io python

$Date$ mysql

摘要 linux

FreeBSD 10.0 的 pkg 沒法安裝php-fpm 最終採用 posts 編譯安裝 nginx

http://netkiller.github.io/journal/freebsd.php.html git

1. PHP 5.5.9

文本格式回覆 shell

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;
#    }
#}
相關文章
相關標籤/搜索