Ubuntu 16.04下源码配置LNMP环境

最近把系统升级到 Ubuntu 16.04长期支持版 ,重新部署了LNMP环境。

约定几个目录  源码目录  /usr/local/src

                  mysql    /usr/local/mysql

                    php   /usr/local/php

                  nginx   /usr/local/nginx

mysql  版本 5.7.14

必备的包和工具

gcc/g++ :MySQL 5.6开始,需要使用g++进行编译。

bison  :MySQL语法解析器需要使用bison进行编译。

libncurses5-dev :用于终端操作的开发包.(注:Debian/Ubuntu下需要安装libncurses5-dev;RedHat下需要安装 ncurses-devel)
zlib    :MySQL使用zlib进行压缩

功能需要的包

libxml2  :用于XML输入输出方式的支持。

openssl  :使用openssl安全套接字方式通信。

dtrace  :用于诊断MySQL问题。

cmake  :MySQL 5.5开始,使用cmake进行工程管理,cmake需要2.8以上版本。

 

sudo apt-get install gcc

sudo apt-get install libxml2

sudo apt-get install  libncurses5-dev bison

安装cmake      下载地址  https://cmake.org/download/

 

建立源码包目录

mkdir /usr/local/src

 

解压

tar zxvf cmake-3.6.1.tar.gz

mv cmake-3.6.1 /usr/local/src

cd cmake-3.6.1

 

编译安装

./configure  make && make install

 

加入环境变量

vim ~/.bashrc

添加

export PATH="/usr/local/src/cmake-3.6.1/bin/cmake:$PATH"

 

从MySQL 5.7.5开始Boost库是必需的,下载Boost库 http://sourceforge.net/projects/boost/files/boost/

tar zxvf boost_1_59_0.tar.gz

mv boost_1_59_0 /usr/local/

 

创建Mysql系统用户组和用户,及数据库存放目录:

mkdir -p /usr/local/mysql/

mkdir -p /usr/local/mysql/data/

 

根据需要另外创建mysql socket 文件保存目录,如果要重新指定存放位置,需要重新编译

groupadd mysql    添加mysql 用户组

useradd mysql -g mysql  添加mysql用户 并指定mysql用户组

chown -R mysql:mysql /usr/local/mysql/  改变指定目录以及其子目录下权限为mysql用户和mysql用户组

 

mysql官方下载地址

http://dev.mysql.com/downloads/mysql/  选择可编译版本

tar zxvf mysql-5.7.14.tar.gz

cd mysql-5.7.14

编译

cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_DATADIR=/usr/local/mysql/data -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_ARCHIVE_STORAGE_ENGINE=1 -DWITH_BLACKHOLE_STORAGE_ENGINE=1 -DWITH_PARTITION_STORAGE_ENGINE=1 -DWITH_PERFSCHEMA_STORAGE_ENGINE=1 -DWITHOUT_EXAMPLE_STORAGE_ENGINE=1 -DWITHOUT_FEDERATED_STORAGE_ENGINE=1 -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_EXTRA_CHARSETS=all -DENABLED_LOCAL_INFILE=1  -DMYSQL_UNIX_ADDR=/usr/local/mysql/data/mysql.sock -DCOMPILATION_COMMENT="string"-DENABLED_PROFILING=1 -DOPTIMIZER_TRACE=1 -DWITH_DEBUG=1 -DWITH_BOOST=/usr/local/boost

make && make install

 

创建数据库服务

在5.5和5.6版本中,mysql数据库是使用mysqld_db_install命令进行初始化的;在5.7之后,数据库初始化发生了改变,需要mysqld命令进行初始化:

/usr/local/mysql/bin/mysqld  --initialize  --user=mysql  --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data/

---以root初始化操作时要加--user=mysql参数,生成一个随机密码(注意保存登录时用)

数据库初始化后,再次修改权限:

chown -R mysql:mysql /usr/local/mysql/data 

 

准备配置文件并启动mysql服务

复制默认配置文件到/etc

cp /usr/local/mysql/support-files/my-default.cnf /etc/my.cnf

改变文件权限为mysql 用户和组

sudo chown mysql:mysql /etc/my.cnf

简单修改一下配置文件

vim /etc/my.cnf

[client]
port = 3306
socket = /usr/local/mysql/data/mysql.sock

[mysqld]
port = 3306
socket = /usr/local/mysql/data/mysql.sock
basedir = /usr/local/mysql
datadir  = /usr/local/mysql/data

 

后台启动mysql

/usr/local/mysql/bin/mysqld_safe --user --defaults-file/etc/my.cnf

 

查看mysql 端口或进程

netstat -altn | grep 3306 或  ps -ef|grep mysql

tcp6      0      0 :::3306                :::*                    LISTEN

 

用初始随机密码登入后修改密码

/usr/local/mysql/bin/mysql -uroot -p

mysql> set password for root@localhost=password('新密码');

Query OK, 0 rows affected, 1 warning (0.00 sec)

 

添加服务,复制启动脚本到/etc/init.d目录

cd /usr/local/mysql/
cp support-files/mysql.server /etc/init.d/mysql

 

设置权限

sudo chmod 755 /etc/init.d/mysql

 

安装ubuntu启动服务管理

sudo apt-get install sysv-rc-conf

sudo sysv-rc-conf mysql on

 

将mysql.service变得可用

systemctl enable mysql.service

 

开启或关闭mysql服务

sudo /etc/init.d/mysql {stop|start}    或者 sudo service mysql start | stop

 

配置环境变量

sudo vim ~/.bashrc

export PATH="/usr/local/mysql/bin/:$PATH"

export PATH

 

Nginx    版本1.10.1

准备工作

需要 zlib 库      http://www.zlib.net/

tar -xvf zlib-1.2.8.tar.gz -C /usr/local/src

mv /usr/local/src/zlib-1.2.8  /usr/local/src/zlib

生成共享库

cd /usr/local/src/zlib

./configure --shared  && make test && make install

cp zutil.h /usr/local/include

cp zutil.c /usr/local/include

mkdir /usr/local/zlib

./configure --prefix=/usr/local/zlib

添加到动态链接库

Add /usr/local/zlib/lib to /etc/ld.so.conf

ldconfig

 

需要 pcre 库      http://www.pcre.org/ 

tar zxvf pcre-8.39.tar.gz -C /usr/local/src

mv /usr/local/src/pcre-8.39 /usr/local/src/prce

cd /usr/local/prce

./configure && make && make install

 

ssl功能需要openssl库  http://www.openssl.org/source/  下载1.0.2g版本

tar zxvf openssl-1.0.2g.tar.gz -C /usr/local/src

cd /usr/local/openssl-1.0.2g

./config --prefix=/usr/local/ shared

make test && make install

添加到动态链接库

Add /usr/local/lib to /etc/ld.so.conf

ldconfig

 

添加nginx 用户和用户组

groupadd www   

useradd www -g www 

chown -R www:www /usr/local/nginx 

 

nginx官网 http://nginx.org/

tar zxvf nginx-1.10.1.tar.gz -C /usr/local/src

cd /usr/local/src/nginx-1.10.1

编译安装

 ./configure --prefix=/usr/local/nginx --with-openssl=/usr/local/src/openssl-1.0.2g --with-pcre=/usr/local/src/pcre --with-zlib=/usr/local/src/zlib --pid-path=/usr/local/nginx/nginx.pid --with-http_ssl_module --with-http_stub_status_module

make && make install

相关推荐