设为首页 收藏本站
查看: 2426|回复: 0

LNMP博客以及数据库分离搭建实战

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2016-5-19 08:47:48 | 显示全部楼层 |阅读模式
nginx搭建命令
cd /home/oldboy/tools 安装存放软件包路径
yum install openssl openssl-devel -y 安装Nginx所需的库、和加密协议
yum install pcre pcre-devel -y 安装Nginx所需的库、和加密协议
rpm -qa openssl-devel pcre-devel  openssl openssl-devel 检查是否安装好
wget -q http://nginx.org/download/nginx-1.6.3.tar.gz 下载软件包
useradd www -s /sbin/nologin -M  创建用户
tar xf nginx-1.6.3.tar.gz 解压软件
cd nginx-1.6.3
./configure --user=www --group=www --with-http_ssl_module --with-http_stub_status_module --prefix=/application/nginx-1.6.3/ 编译安装
make
make install
ln -s /application/nginx-1.6.3/ /application/nginx
/application/nginx/sbin/nginx 开启服务
ps -ef|grep nginx 检查
创建网页目录
[iyunv@web02 html]# mkdir {www,bbs,blog} -p
[iyunv@web02 www]# echo "www.etiantian.org" >index.html

修改主配置文件
添加access日志及虚拟主机目录
    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                       '$status $body_bytes_sent "$http_referer" '
                       '"$http_user_agent" "$http_x_forwarded_for"';

#nginx vhosts config
    include extra/www.conf;
    include extra/bbs.conf;
    include extra/blog.conf;


创建存放虚拟主机的目录
[iyunv@web02 conf]# mkdir extra
[iyunv@web02 extra]# touch www.conf
[iyunv@web02 extra]# touch bbs.conf
[iyunv@web02 extra]# touch blog.conf
修改每个虚拟主机的conf目录
   server {
        listen       80;
        server_name  www.etiantian.org etiantian.org;
        location / {
            root   html/www;
            index  index.html index.htm;
        }
        access_log logs/access_www.log main;
        }

设置开机启动
[iyunv@web02 oldboy]# echo "/application/nginx/sbin/nginx " >>/etc/rc.local
[iyunv@web02 oldboy]# tail -1 /etc/rc.local
/application/nginx/sbin/nginx



MySQL搭建命令
安装MySQL
上传MySQL  
ls mysql-5.5.49-linux2.6-x86_64.tar.gz
tar xf mysql-5.5.49-linux2.6-x86_64.tar.gz
mkdir /application -p
mv mysql-5.5.49-linux2.6-x86_64 /application/mysql-5.5.49
ln -s /application/mysql-5.5.49 /application/mysql
useradd mysql -s /sbin/nologin -M 创建用户和授权目录
chown -R mysql.mysql /application/mysql/ 创建用户和授权目录
cd /application/mysql
./scripts/mysql_install_db --user=mysql --basedir=/application/mysql --datadir=/application/mysql/data/ 初始化时数据库
ll data/
\cp support-files/my-small.cnf  /etc/my.cnf 创建基本需求
cp support-files/mysql.server /etc/init.d/mysqld 创建基本需求
chmod +x /etc/init.d/mysqld  给执行权限
sed -i 's#/usr/local/mysql#/application/mysql#g' /application/mysql/bin/mysqld_safe /etc/init.d/mysqld 修改配置文件
/etc/init.d/mysqld start 开启服务、
netstat -lntup|grep mysql 检查
echo "PATH="/application/mysql/bin:$PATH"" >>/etc/profile
chkconfig --add mysqld 开启服务
chkconfig mysqld on 开启服务
cp -a /application/mysql/bin/* /usr/local/sbin/
ln -s /application/mysql/bin/* /usr/local/sbin/
mysql


1、安装PHP基础库
yum install zlib-devel libxml2-devel libjpeg-devel libjpeg-turbo-devel libiconv-devel -y
yum install freetype-devel libpng-devel gd-devel libcurl-devel libxslt-devel libxslt-devel -y
rpm -qa zlib-devel libxml2-devel libjpeg-devel libjpeg-turbo-devel libiconv-devel freetype-devel libpng-devel gd-devel libcurl-devel libxslt-devel
需要先安装支持的软件包
cd /home/oldboy/tools
wget http://ftp.gnu.org/pub/gnu/libiconv/libiconv-1.14.tar.gz
tar zxf libiconv-1.14.tar.gz
cd libiconv-1.14
./configure --prefix=/usr/local/libiconv
make
make install
cd ../

2、PHP相关扩展库
wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-6.repo
yum -y install libmcrypt-devel
yum -y install mhash
yum -y install mcrypt
rpm -qa libmcrypt-devel mhash mcrypt

解压php安装包,编辑
上传PHP包
tar xf php-5.5.32.tar.gz 解压php安装包
./configure \
--prefix=/application/php5.5.32 \
--with-mysql=/application/mysql/ \
--with-pdo-mysql=mysqlnd \
--with-iconv-dir=/usr/local/libiconv \
--with-freetype-dir \
--with-jpeg-dir \
--with-png-dir \
--with-zlib \
--with-libxml-dir=/usr \
--enable-xml \
--disable-rpath \
--enable-bcmath \
--enable-shmop \
--enable-sysvsem \
--enable-inline-optimization \
--with-curl \
--enable-mbregex \
--enable-fpm \
--enable-mbstring \
--with-mcrypt \
--with-gd \
--enable-gd-native-ttf \
--with-openssl \
--with-mhash \
--enable-pcntl \
--enable-sockets \
--with-xmlrpc \
--enable-soap \
--enable-short-tags \
--enable-static \
--with-xsl \
--with-fpm-user=www \
--with-fpm-group=www \
--enable-ftp \
--enable-opcache=no


ln -s /application/mysql/lib/libmysqlclient.so.18  /usr/lib64/
touch ext/phar/phar.phar

make
make install
ln -s /application/php5.5.32/ /application/php
ls /application/php/
cp php.ini-production /application/php/lib/php.ini
配置php解析文件
cp php.ini-production /application/php/lib/php.ini
配置php-fpm配置文件
cp php-fpm.conf.default php-fpm.conf
启动php-fpm
/application/php/sbin/php-fpm
lsof -i :9000
ps -ef|grep php-fpm

root@web01 extra]# cat blog.conf      
    server {
        listen       80;
        server_name  blog.etiantian.org;
        location / {
            root   html/blog;
            index  index.html index.htm;
        }
        location ~ .*\.(php|php5)?$ {
            root html/blog;
            fastcgi_pass  127.0.0.1:9000;
            fastcgi_index index.php;
            include fastcgi.conf;
        }
    }
[iyunv@web01 extra]# ../../sbin/nginx  -t
nginx: the configuration file /application/nginx-1.6.3//conf/nginx.conf syntax is ok
nginx: configuration file /application/nginx-1.6.3//conf/nginx.conf test is successful
[iyunv@web01 extra]# ../../sbin/nginx  -s reload
[iyunv@web01 blog]# cat test_mysql.php
<?php
        $link_id=mysql_connect('localhost','root','oldboy123') or mysql_error();
        if($link_id){
                echo "mysql successful by oldboy !";
        }else{
                echo mysql_error();
        }
?>



搭建blog命令
mysql -uroot -poldboy123
create database wordpress;
show databases;
grant all on wordpress.* to wordpress@'localhost' identified by '123456';
select user,host from mysql.user;
show grants for wordpress@'localhost';
flush privileges;

下载博客安装
wget https://cn.wordpress.org/wordpress-4.5.1-zh_CN.tar.gz
  ll
tar xf wordpress-4.5.1-zh_CN.tar.gz
ls wordpress
cp -a wordpress/* /application/nginx/html/blog/
ls /application/nginx/html/blog/
chown -R www.www /application/nginx/html/blog/
ls /application/nginx/html/blog/
ls /application/nginx/html/blog/ -l
history


分离命令
wed命令
mysqldump -uroot -poldboy123 wordpress -B |gzip>bak.sql.gz
scp bak.sql.gz  root@10.0.0.51:/tmp

数据库MySQL命令
cd /tmp
gzip xf bak.sql.tar.gz
mysql -uroot -poldboy123 -e "show databases like 'wordpress';"
mysql -uroot -poldboy123 -e "use wordpress;show tables;"
mysql -uroot -poldboy123
grant all on wordpress.* to wordpress@'172.16.1.%' identified by '123456';
flush privileges;
select user,host from mysql.user;


更改.8配置文件 wp-config.php
32 define('DB_HOST', '172.16.1.51');
关闭本地数据库
/etc/init.d/mysqld stop
chkconfig mysqld off
成功。

2、将blog的资源文件迁移到NFS
[iyunv@web01 blog]# tree wp-content/uploads/
资源目录为:wp-content/uploads/

nfs命令
echo "/uploads 172.16.1.0/24(rw,sync)" /etc/exports
MySQL数据库命令
mount -t nfs  172.16.1.31:/uploads /application/nginx/html/blog/




运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-218899-1-1.html 上篇帖子: LNMP环境搭建(基于zabbix监控软件) 下篇帖子: nginx负载均衡LAMP及基于memcached实现php会话保存 数据库 博客
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表