zoukankan      html  css  js  c++  java
  • CentOS6.7安装部署LNMP(nginx1.8.0+php5.6.10+mysql5.6.12)

    IP-10.0.0.8

    1.安装nginx

    mkdir -p /server/tools
    cd /server/tools
    yum install -y pcre pcre-devel openssl openssl-devel gcc gcc+
    wget http://nginx.org/download/nginx-1.8.0.tar.gz
    useradd www -M -s /sbin/nologin
    tar xf nginx-1.8.0.tar.gz
    cd nginx-1.8.0/
    sed -i "179s/#//" auto/cc/gcc
    mkdir /application
    ./configure --prefix=/application/nginx-1.8.0 --user=www 
    --group=www --with-http_stub_status_module --with-http_ssl_module
    make && make install
    ln -s /application/nginx-1.8.0/ /application/nginx
    # Centos7采用yum方式安装nginx
    rpm -Uvh http://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.noarch.rpm
    yum -y install nginx
    systemctl start nginx.service
    

    2.安装php

    yum -y install zlib-devel libxml2-devel libjpeg-devel libjpeg-turbo-devel
    libpng-devel freetype-devel libcurl-devel gd-devel libxslt-devel 
    mhash mcrypt libmcrypt libmcrypt-devel  
    # libiconv-devel没有这包
    cd /server/tools/
    wget http://ftp.gnu.org/pub/gnu/libiconv/libiconv-1.14.tar.gz
    tar xf libiconv-1.14.tar.gz
    cd libiconv-1.14/
    ./configure --prefix=/usr/local/libiconv
    make && make install
    # PHP的编译参数
    cd /server/tools/
    wget http://cn2.php.net/distributions/php-5.6.10.tar.gz
    tar -zxvf php-5.6.10.tar.gz
    cd php-5.6.10
    ./configure --prefix=/opt/php --with-mysql 
    --with-mysqli=mysqlnd --with-pdo-mysql=mysqlnd 
    --with-iconv-dir=/usr/local/libiconv  --with-zlib 
    --with-libxml-dir --enable-xml --with-curl --enable-fpm 
    --enable-mbstring --with-gd --with-openssl --with-mhash 
    --enable-sockets --with-xmlrpc --enable-zip --enable-soap 
    --with-libdir=/usr/lib64 --with-jpeg-dir=/usr/lib64 
    --with-freetype-dir=/usr/lib64 --with-png-dir=/usr/lib64 
    --with-xsl --with-fpm-user=www --with-fpm-group=www
    make
    make install clean
    

    3.解决问题

    # 安装MySQL参考上一篇博文
    # 解决缺少共享库的问题,两种方法(先用find查到这个库的位置):
    vi /etc/ld.so.conf
    /opt/mysql-5.6.21/libmysql/
    ldconfig  # 生效
    ln -s /opt/mysql-5.6.21/libmysql/libmysqlclient.so.18 /usr/lib64/
    # 如果make的时候报:ext/phar/phar.phar没有这个文件
    cd php-5.6.10
    touch ext/phar/phar.phar
    # 本机没有安装mysql时,可以使用下面的参数
    --enable-mysqlnd
    --with-mysqli=mysqlnd
    --with-pdo-mysql=mysqlnd
    # 配置并启动php-fpm
    cp php.ini-production /opt/php/lib/php.ini
    cd /opt/php/etc/
    cp php-fpm.conf.default php-fpm.conf
    cd /server/tools/php-5.6.10/sapi/fpm/
    cp init.d.php-fpm /etc/init.d/php-fpm
    chmod +x /etc/init.d/php-fpm
    service php-fpm start # 或者/opt/php/sbin/php-fpm
    
    cat blog.conf
    server {
        listen       80;
        server_name  blog.etiantian.com;
        location / {
            root html/blog;
            index index.php index.html;
        }
        location ~.*.(php|php5)?$ {
            root html/blog;
            fastcgi_pass 127.0.0.1:9000;
            fastcgi_index index.php;
            include fastcgi.conf;
        }
    }
    /application/nginx/sbin/nginx -s reload
    mkdir /application/nginx/html/blog/
    echo "<?php phpinfo(); ?>" > /application/nginx/html/blog/test.php
    # 连接数据库测试
    cat /application/nginx/html/blog/conn_mysql.php
    <?php
    	$con = mysql_connect("localhost","root","root123") or mysql_error();
    	if ($con){
    		echo "connect mysql successfully";
    	}
    	else{
    		echo mysql_error();  
    	}
    ?>
    

    4.搭建WordPress博客

    create database wordpress;
    grant all on wordpress.* to wordpress@'localhost' identified by '123456';
    show grants for wordpress@'localhost'G;
    # 如果授权授大了,在user表中删除用户是不行的,得drop然后重新授权
    drop user wordpress@'localhost';
    # revoke貌似不太好使
    revoke all on *.* from wordpress@localhost;
    
    wget https://cn.wordpress.org/wordpress-4.5.1-zh_CN.tar.gz
    cp -a wordpress/* /application/nginx/html/blog/
    # 这个权限是为了让先能用,以后还要改
    chown -R www.www /application/nginx/html/blog/
    # 现在blog目录下的文件有22个,安装后会多出一个配置文件
    # 访问blog.etiantian.com,点击安装,会生成一个连接数据库的配置文件--wp-config.php
    # 图片上传目录为:/application/nginx/html/blog/wp-content/uploads
    

    5.分离数据库

    # 导出wordpress数据并修改连接数据库的文件(web01上)
    vi wp-config.php
    define('DB_HOST', '172.16.1.51');
    mysqldump -uroot -poldboy123456 wordpress -B | gzip > bak.sql.gz
    # 导入数据(db01上)
    mysql -uroot -poldboy123456 < /tmp/bak.sql
    grant all on wordpress.* to wordpress@'172.16.1.%' identified by '123456';
    # 在其他服务器上就能以这样的语句访问51的数据库了
    mysql -u wordpress -h 172.16.1.51 -p
    

    6.静态图片放在nfs上

    # 10.0.0.31是之前的NFS服务器,在10.0.0.31上创建用户,与10.0.0.8上的www的id相同
    useradd -u 891 www
    vi /etc/exports
    /data 172.16.1.0/24(rw,sync,all_squash,root_squash,anonuid=891,anongid=891)
    mkdir /data/nfs-blog
    chown -R www.www /data/
    # 在web01上操作
    rpm -qa rpcbind nfs-utils
    /etc/init.d/rpcbind status
    cd /application/nginx/html/blog/wp-content/uploads
    mv 2018 /tmp/
    mount -t nfs 172.16.1.31:/data/nfs-blog /application/nginx/html/blog/wp-content/uploads/
    cp -a /tmp/2018/ .
    排错:
    touch: cannot touch `aaa': Permission denied
    # 挂载完之后,无法创建文件,是因为在/etc/exports中将anonuid写成了893,
    # 在改成891之后,还是无法写入,重启客户端rpcbind之后,可以正常写入.
    

    7.wordpress实现伪静态

    管理站点-设置-固定链接-自定义结构:
    /archives/%post_id%.html
    文章的url就会变成这样的形式:
    http://blog.etiantian.com/archives/9.html
    
    cat blog.conf
    server {
        listen       80;
        server_name  blog.etiantian.com;
        location / {
            root html/blog;
            index index.php index.html;
            try_files $uri $uri/ /index.php?$args;
        }
        location ~ .*.(php|php5)?$ {
            root html/blog;
            fastcgi_pass 127.0.0.1:9000;
            fastcgi_index index.php;
            include fastcgi.conf;
        }
    
    }
    
  • 相关阅读:
    DEV GridView显示行号
    winfrom Log4Net 代码(二) 记录格式log_info.txt和log_error.txt,只产生两个文本,里面分别记录提示信息和报错信息
    VB.NET使用Log4Net
    Log4Net使用中loginfo.IsInfoEnabled=false问题解决方法
    VB.NET 根据当前日期获取星期几
    VB.NET 发送outLook邮件body基于Html样式
    VB.NET NPOI快速导入导出Excel
    python使用cx_oracle连接oracle数据库
    物理STANDBY库创建还原点(打开为READ WRITE后再变回STANDBY库)
    oracle RAC和RACOneNode之间的转换
  • 原文地址:https://www.cnblogs.com/fawaikuangtu123/p/10168821.html
Copyright © 2011-2022 走看看