LNMP代表的就是:Linux系统下Nginx+MySQL+PHP这种网站服务器架构。
Linux是一类Unix计算机操作系统的统称,是目前最流行的免费操作系统。代表版本有:debian、CentOS、Ubuntu、Fedora、gentoo等。
Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器
Mysql是一个小型关系型数据库管理系统。
PHP是一种在服务器端执行的嵌入HTML文档的脚本语言。
这四种软件均为免费开源软件,组合到一起,成为一个免费、高效、扩展性强的网站服务系统。
(一)首先需要安装一个Ubuntu系统,我是在虚拟机上安装的,过程非常简单
安装好后就可以在系统上装nginx、mysql、php了。
我们先要配置系统的网卡,让他可以上网,并设置他的DNS
root@linuxidc:~# vim /etc/network/interfaces
root@linuxidc:~# vim /etc/resolv.conf
然后重启网卡,Ubuntu和centos重启网卡的命令并不相同
root@linuxidc:~# ifdown eth0 && ifup eth0
查看一下网卡信息确认是否已经配置好
(二)
然后进行下一步,安装nginx,可以到官网下载,找到稳定版
打开/etc/apt/source.list文件,将下面两行命令粘贴到文件的末尾,不要粘错了!!
deb codename nginx
deb-src codename nginx
然后将codename改成trusty,不同版本的系统替换的单词不同,到官网查找即可
下载秘钥
root@linuxidc:~# wget
下载后执行下面的这条命令
root@linuxidc:~# apt-key add nginx_signing.key
最后更新源,安装nginx,启动nginx
root@linuxidc:~# apt-get update
root@linuxidc:~# apt-get install nginx
root@linuxidc:~# service nginx start
我们看一下80端口起来没有
root@linuxidc:~# netstat -ntpl | grep 80
设置一下防火墙允许80端口通过,ubuntu和centos命令也不同
root@linuxidc:~# ufw allow 80
用浏览器登录本机ip地址,就可以看到nginx的欢迎页面了
(三)
nginx装好后就可以安装mysql了
先建立mysql相关的用户、组、文件夹,将新建的目录递归设置属主mysql和属组mysql
root@linuxidc:~# groupadd mysql
root@linuxidc:~# useradd -g mysql mysql -s /bin/false
root@linuxidc:~# mkdir -p /Disk/data/mysql/var
root@linuxidc:~# chown -R mysql:mysql /Disk/data/mysql/var
解压mysql包。
root@linuxidc:~# tar zxvf mysql-5.5.35.tar.gz
安装一些程序包,否则后面会报错
root@linuxidc:~# apt-get install g++
root@linuxidc:~# apt-get install libaio1
root@linuxidc:~# apt-get install libncurses5-dev
root@linuxidc:~# apt-get install libncurses5
root@linuxidc:~# wget
root@linuxidc:~# tar zxvf bison-2.5.1.tar.gz
root@linuxidc:~# cd bison-2.5.1/
root@linuxidc:~/cd bison-2.5.1# ./configure
在配置过程中会出错,是因为没有安装m4
root@linuxidc:~/cd bison-2.5.1# apt-get install m4
Ubuntu中没有make命令,安装一下。在Ubuntu中用apt-get命令
root@linuxidc:~/cd bison-2.5.1# apt-get install make
root@linuxidc:~/cd bison-2.5.1# make && make install
然后进行mysql的安装
root@linuxidc:~# cd mysql-5.5.35/
root@linuxidc:~/mysql-5.5.35# cmake . -DCMAKE_INSTALL_PREFIX=/Disk/local/mysql-DMYSQL_DATADIR=/Disk/data/mysql/var -DSYSCONFDIR=/etc
你会看到Ubuntu上cmake命令也没有
root@linuxidc:~/mysql-5.5.35# apt-get install cmake
再cmake一下,如果还报错,就rm CMakeCache.txt
成功后编译安装
root@linuxidc:~/mysql-5.5.35# make && make install
mysql安装好后就可以进行配置了,一定要在安装目录下进行
root@linuxidc:~# cd /Disk/local/mysql
root@linuxidc:~/Disk/local/mysql# cp ./support-files/my-huge.cnf /etc/my.cnf
修改配置文件,做好备份
root@linuxidc:~/Disk/local/mysql# vim /etc/my.cnf
root@linuxidc:~/Disk/local/mysql# mv /etc/my.cnf /etc/my.cnf.bak
root@linuxidc:~/Disk/local/mysql# vim /etc/my.cnf.bak
root@linuxidc:~/Disk/local/mysql# vim /etc/my.cnf
将以下配置写到配置文件中
[client]
port = 3306
socket = /tmp/mysql.sock
[mysqld]
datadir = /Disk/data/mysql/var
port = 3306
socket = /tmp/mysql.sock
skip-external-locking
key_buffer_size = 256M
max_allowed_packet = 20M
sort_buffer_size = 2M
read_buffer_size = 2M
read_rnd_buffer_size = 8M
myisam_sort_buffer_size = 64M
#server-id = 1
#xzy
thread_stack = 192K
thread_cache_size = 64
myisam-recover = BACKUP
max_connections = 5000
query_cache_limit = 2M
query_cache_size = 256M
#错误日志记录
log_error = /Disk/log/mysql/error.log
#慢查询日志
#slow-query-log = /Disk/log/mysql/mysql-slow.log
#long_query_time = 5
#log-queries-not-using-indexes
#二进制文件日志
log_bin = /Disk/log/mysql/mysql-bin.log
binlog_format = row
expire_logs_days = 10
max_binlog_size = 100M
#不区分大小写
lower_case_table_names=1
[mysqldump]
quick
max_allowed_packet = 16M
[mysql]
no-auto-rehash
[myisamchk]
key_buffer_size = 256M
sort_buffer_size = 256M
read_buffer = 2M
write_buffer = 2M
[mysqlhotcopy]
interactive-timeout
新建日志文件,并设置属主和属组
root@linuxidc:~/Disk/local/mysql#kdir -p /Disk/log/mysql
root@linuxidc:~/Disk/local/mysql# chown -R mysql:mysql /Disk/log/mysql
初始化数据库
root@linuxidc:~/Disk/local/mysql# /Disk/local/mysql/scripts/mysql_install_db --user=mysql
把mysql加入系统启动,他会告诉你找不到/etc/rc.d/init.d/mysqld文件
root@linuxidc:~/Disk/local/mysql# cp ./support-files/mysql.server /etc/rc.d/init.d/mysqld
此时进入当前目录下的support-files/目录
root@linuxidc:~/Disk/local/mysql/support-files# ./mysql.server restart
这样就将mysql启动起来了
mysql使用3306端口,将3306端口加入防火墙
root@linuxidc:~# ufw allow 3306
查看防火墙状态
root@linuxidc:~# ufw status