LNMP原理及安装

LNMP:

  • 目前成熟的企业网站的应用模式之一,指的是一套协同工作的系统和相关软件能够提供静态页面服务,也可以提供动态web服务

LNMP的组成:

  • L  :表示linux系统,操作系统
  • N :表示nginx网站服务,前端,提供前端的静态页面服务。同时具有代理,转发的作用。 转发后端请求。转发到PHP。nginx没有处理动态资源的功能,他有可以支持转发动态请求的模块
  • M :表示mysql 关系型数据库,保存用户的账号和密码
  • P  :  表示PHP 动态页面的编程语言,负责解释动态网页文件,和nginx以及数据库协同工作。         PHP的主要作用就是web开发,前端开发

编译安装:

就是用二进制包,进行安装

和yum安装的区别:

  • yum安装只是安装了基础的服务模块,其他的模块要根使用,用户要于动重新添加。
  • 编译安装可以白由的指定需要的模块

       企业中: nginx mysql 都是编译安装。

LNMP安装:

关闭防火墙和安全机制

systemctl stop firewalld.service 
setenforce 0

1、安装 Nginx 服务

安装依赖环境

yum -y install pcre-devel zlib-devel gcc gcc-c++ make

创建运行用户

useradd -M -s /sbin/nologin nginx

将nginx压缩包解压在opt目录下

tar zxvf nginx-1.22.0.tar.gz -C /opt/

配置安装路径

cd nginx-1.22.0/
./configure \
--prefix=/usr/local/nginx \
--user=nginx \
--group=nginx \
--with-http_stub_status_module

编译安装  ( -j 4  表示指定cpu核心数4个,提升处理速度 )

make -j 4 && make install

优化路径

ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/

添加 Nginx 系统服务

vim /lib/systemd/system/nginx.service
[Unit]       #这个部分定义了服务单元的元数据。
Description=nginx         #描述该服务单元的信息,描述为"nginx"。
After=network.target      #定义服务单元所依赖的其他单元,这里表示服务需要在网络加载完成之后启动
[Service]    #这个部分定义了服务的运行配置
Type=forking       #指定服务的类型,这里是forking,表示服务是一个后台进程(通常是fork出子进程)
PIDFile=/usr/local/nginx/logs/nginx.pid      #指定保存主进程ID的文件路径,Nginx将会把主进程ID写入这个文件,以便Systemd可以追踪和管理进程
ExecStart=/usr/local/nginx/sbin/nginx        #指定启动服务的命令。这里是启动Nginx的命令/usr/local/nginx/sbin/nginx
ExecReload=/bin/kill -s HUP $MAINPID         #指定重新加载配置的命令。当执行此命令时,Systemd将发送HUP信号给主进程,Nginx将重新加载配置文件
ExecStop=/bin/kill -s QUIT $MAINPID          #指定停止服务的命令。当执行此命令时,Systemd将发送QUIT信号给主进程,Nginx将优雅地停止服务
PrivateTmp=true     #将此项设置为true,表示为服务提供独立的临时目录
[Install]       #这个部分定义了服务的安装配置
WantedBy=multi-user.target     #指定服务所属的目标(target),这里是multi-user.target,表示服务在多用户模式下启动。

给该文件赋权并重启服务

chmod 777 /lib/systemd/system/nginx.service

systemctl start nginx.service

网页访问本机地址,网页能正常打开,说明nginx服务没有问题

LNMP原理及安装_第1张图片

 

2、安装mysql服务

安装依赖环境

yum -y install \
ncurses \
ncurses-devel \
bison \
cmake

创建运行用户

useradd -M -s /sbin/nologin  mysql

将mysql压缩包解压在opt目录下

cd /opt
tar zxvf mysql-boost-5.7.20.tar.gz

配置安装路径

cd /opt/mysql-5.7.20/
cmake \
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql \       #指定mysql的安装路径
-DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \   #指定mysql进程监听套接字文件(数据库连接文件)的存储路径
-DSYSCONFDIR=/etc \      #指定配置文件的存储路径
-DSYSTEMD_PID_DIR=/usr/local/mysql \     #指定进程文件的存储路径
-DDEFAULT_CHARSET=utf8  \       #指定默认使用的字符集编码,如utf8
-DDEFAULT_COLLATION=utf8_general_ci \    #指定默认使用的字符集校对规则
-DWITH_EXTRA_CHARSETS=all \     
-DWITH_INNOBASE_STORAGE_ENGINE=1 \    #安装INNOBASE存储引擎
-DWITH_ARCHIVE_STORAGE_ENGINE=1 \     #安装ARCHIVE存储引擎
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \    #安装BLACKHOLE存储引擎
-DWITH_PERFSCHEMA_STORAGE_ENGINE=1 \    #安装FEDERATED存储引擎
-DMYSQL_DATADIR=/usr/local/mysql/data \    #指定数据库文件的存储路径
-DWITH_BOOST=boost \    #指定boost的路径,
-DWITH_SYSTEMD=1     #生成便于systemctl管理的文件

编译安装前先清理内存

free -h   #查看内存
echo 1 > /proc/sys/vm/drop_caches

编译安装

make -j 4 && make install

修改mysql 配置文件

vim /etc/my.cnf
[client]                    
port = 3306
socket=/usr/local/mysql/mysql.sock
#在[client]节中
#port: 客户端连接MySQL服务器使用的端口号,默认为3306
#socket: 客户端连接MySQL服务器使用的Unix socket文件路径,默认为/tmp/mysql.sock。在该配置文件中指定的路径是/usr/local/mysql/mysql.sock

[mysqld]
user = mysql    #MySQL服务器运行时的用户名,一般设置为mysql
basedir=/usr/local/mysql   #Mysql安装目录的路径
datadir=/usr/local/mysql/data    #存放Mysql数据文件的路径
port = 3306    #MySQL服务器监听的端口号,默认为3306
character-set-server=utf8   #MySQL服务器使用的默认字符集,这里设置为UTF-8编码(utf8)
pid-file = /usr/local/mysql/mysqld.pid   #保存MySQL服务器进程ID的文件路径,默认为/var/run/mysqld/mysqld.pid。在该配置文件中指定的路径是/usr/local/mysql/mysqld.pid
socket=/usr/local/mysql/mysql.sock   #MySQL服务器监听的Unix socket文件路径,默认为/tmp/mysql.sock。在该配置文件中指定的路径是/usr/local/mysql/mysql.sock
bind-address = 0.0.0.0   #MySQL服务器绑定的IP地址,默认为127.0.0.1,这里设置为0.0.0.0表示允许任何IP地址访问MySQL服务器
skip-name-resolve   #禁用DNS反向解析,可以提高性能,尤其是在有大量连接时
max_connections=2048   #MySQL服务器支持的最大并发连接数,默认为151,这里设置为2048
default-storage-engine=INNODB   #设置默认的存储引擎为InnoDB
max_allowed_packet=16M   #设置MySQL服务器接收的最大数据包大小,默认为4MB,这里设置为16MB
server-id = 1   #设置MySQL服务器的唯一ID,在主从复制设置中使用

sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_AUTO_VALUE_ON_ZERO,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,PIPES_AS_CONCAT,ANSI_QUOTES

更改mysql安装目录和配置文件的所有者和所在组

chown -R mysql:mysql /usr/local/mysql/
chown mysql:mysql /etc/my.cnf

设置路径环境变量并立即生效

echo 'export PATH=/usr/local/mysql/bin:/usr/local/mysql/lib:$PATH' >> /etc/profile

source /etc/profile

初始化数据库

cd /usr/local/mysql/bin/
./mysqld \
--initialize-insecure \
--user=mysql \
--basedir=/usr/local/mysql \
--datadir=/usr/local/mysql/data

添加mysqld系统服务

cp /usr/local/mysql/usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system/
systemctl daemon-reload
systemctl start mysqld.service
systemctl enable mysqld

修改mysql 的登录密码

mysqladmin -u root -p password "123456"

授权远程登录

mysql -u root -p

grant all privileges on *.* to 'root'@'%' identified by '123456';
#授予root用户可以在所有终端远程登录,使用的密码是123456,并对所有数据库和所有表有操作权限

刷新权限

flush privileges;

你可能感兴趣的:(linux)