LNMP应用环境介绍之MySQL的安装

LNMP是一种web服务环境组合,是由Linux、Nginx、MySQL、PHP等组合搭建的,当其工作时,首先是用户通过浏览器输入域名请求Nginx Web 服务,如果请求的是静态资源,则由Nginx解析返回给用户,如果是动态请求(以.php结尾),那么Nginx就会把它通过FastCGI接口(生产常用方法)发送给PHP 引擎服务(FastCGI进程php-fpm)进行解析,如果这个动态请求要读取数据库数据,那么PHP会继续向后请求MySQL数据库,以读取需要的数据,并最终通过Nginx服务把获取的数据返回给用户,这就是LNMP环境的基本请求顺序流程。

我们在部署LNMP之前首先安装软件MySQL,这里需要注意的是,MySQL安装要与Nginx安装在同一台机器上

首先创建MySQL用户的账户

[root@web1 ~]# useradd -s /sbin/nologin -g mysql -M mysql
useradd:“mysql”组不存在

[root@web1 ~]# groupadd mysql    #添加组
[root@web1 ~]# useradd -M -s /sbin/nologin mysql -g mysql     

[root@web1 ~]# id mysql      #创建成功
uid=8890(mysql) gid=10000(mysql) 组=10000(mysql)

建立存放所有软件的固定目录

[root@web1 ~]# mkdir -p /home/wangju/tools
[root@web1 ~]# cd /home/wangju/tools

获取MySQL软件包,从官网上下载二进制软件包,网址:https://downloads.mysql.com/archives/community/,然后将文件传输到Linux系统中的指定位置,并检查是否传输完成。

[root@web1 tools]# rz -E
rz waiting to receive.
[root@web1 tools]# ls
mysql-5.7.26-linux-glibc2.12-x86_64.tar.gz nginx-1.16.0 nginx-1.16.0.tar.gz
[root@web1 tools]# echo $?    #出现0表示传输完成
0

[root@web1 tools]# tar xf mysql-5.7.26-linux-glibc2.12-x86_64.tar.gz     #解压压缩包
[root@web1 tools]# echo $?  #解压成功
0
[root@web1 tools]# ls
mysql-5.7.26-linux-glibc2.12-x86_64 nginx-1.16.0
mysql-5.7.26-linux-glibc2.12-x86_64.tar.gz nginx-1.16.0.tar.gz
[root@web1 tools]# mv mysql-5.7.26-linux-glibc2.12-x86_64 /application/mysql-5.7.26       #将解压后的文件移动并改名
[root@web1 tools]# ln -s /application/mysql-5.7.26/ /application/mysql      #将改名后的文件设置软连接
[root@web1 tools]# ll /application
总用量 0
lrwxrwxrwx 1 root root 26 6月 21 10:57 mysql -> /application/mysql-5.7.26/
drwxr-xr-x 9 root root 129 6月 21 10:52 mysql-5.7.26
lrwxrwxrwx. 1 root root 25 6月 2 19:43 nginx -> /application/nginx-1.16.0
drwxr-xr-x. 11 root root 151 6月 2 20:02 nginx-1.16.0

初始化MySQL的配置文件

[root@web1 tools]# cd /application/mysql
[root@web1 mysql]# find ./ -name "*.conf"    #查找带有.conf的配置文件,没有找到

[root@web1 mysql]# ls
bin COPYING docs include lib man README share support-files

[root@web1 mysql]# ll support-files   
总用量 24
-rw-r--r-- 1 7161 31415 773 4月 13 2019 magic
-rwxr-xr-x 1 7161 31415 1061 4月 13 2019 mysqld_multi.server
-rwxr-xr-x 1 7161 31415 894 4月 13 2019 mysql-log-rotate
-rwxr-xr-x 1 7161 31415 10576 4月 13 2019 mysql.server
[root@web1 mysql]# rpm -e --nodeps mariadb-libs     #卸载掉系统自动安装的mariadb库,防止冲突
[root@web1 mysql]# echo $?    #卸载成功
0

[root@web1 mysql]# vim /etc/my.cnf     #手动编写配置文件/etc/my.cnf

[mysqld] #服务器模块名称
basedir = /application/mysql/ #MySQL安装目录
datadir = /application/mysql/data #MySQL数据文件目录
socket = /tmp/mysql.sock #MySQL服务器sock文件目录
server_id = 1 #MySQL实例ID
port = 3306 #MySQL默认端口
log_error = /application/mysql/data/wangju_mysql.err #MySQL错误日志路径

[mysql] #MySQL客户端模块名
socket = /tmp/mysql.sock #MySQL客户端sock文件目录
prompt = wangju [\\d]> #MySQL登录提示符

初始化MySQL数据库文件

首先安装依赖的包

[root@web1 mysql]# yum install libaio-devel -y
已加载插件:fastestmirror, langpacks
Loading mirror speeds from cached hostfile
* base: mirrors.aliyun.com
* extras: mirrors.aliyun.com
* updates: mirrors.aliyun.com
base

-------------------------------------------------------------------------------

省略部分输出

-------------------------------------------------------------------------------

创建数据文件目录并授权

[root@web1 mysql]# mkdir /application/mysql/data  #建立数据文件目录
[root@web1 application]# chown -R mysql.mysql /application/mysql/   #给MySQL授权于用户mysql
[root@web1 application]# ls -ld /application/mysql/  
drwxr-xr-x 10 mysql mysql 141 6月 21 11:40 /application/mysql/
[root@web1 application]# /application/mysql/bin/mysqld --initialize-insecure --user=mysql --basedir=/application/mysql/ --datadir=/application/mysql/data    #初始化数据库(如果未出现error就表示授权成功)
2021-06-21T03:47:35.198943Z 0 [Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use --explicit_defaults_for_timestamp server option (see documentation for more details).
2021-06-21T03:47:36.937244Z 0 [Warning] InnoDB: New log files created, LSN=45790
2021-06-21T03:47:37.182665Z 0 [Warning] InnoDB: Creating foreign key constraint system tables.
2021-06-21T03:47:37.533723Z 0 [Warning] No existing UUID has been found, so we assume that this is the first time that this server has been started. Generating a new UUID: 6ba1bfd0-d243-11eb-bcb9-000c296b7730.
2021-06-21T03:47:37.591100Z 0 [Warning] Gtid table is not ready to be used. Table 'mysql.gtid_executed' cannot be opened.
2021-06-21T03:47:37.609538Z 1 [Warning] root@localhost is created with an empty password ! Please consider switching off the --initialize-insecure option.

  --user=mysql    #MySQL的用户

  --basedir=/application/mysql/      #MySQL的根目录

  --datadir=/application/mysql/data       #MySQL数据文件目录

  --initialize-insecure         #关闭MySQL的安全策略,这里我们选择关闭

  --initialize      #开启MySQL的安全策略,高安全环境采用

配置并启动MySQL数据库

首先,设置启动脚本,在centos7 中使用systemctl 来管理任务

[root@web1 mysql]# vim /etc/systemd/system/mysqld.service
[root@web1 mysql]# cat /etc/systemd/system/mysqld.service
[Unit]
Description=MySQL Server by wangju
Documentation=man:mysql(8)
Documentation=http://dev.mysql.com/doc/refman/en/using-systemd.html
After=network.target
After=syslog.target
[Install]
WantedBy=multi-user.target
[Service]
User=mysql
Group=mysql
ExecStart=/application/mysql/bin/mysqld --defaults-file=/etc/my.cnf
LimitNOFILE = 5000

启动MySQL数据库

[root@web1 mysql]# systemctl start mysqld

[root@web1 mysql]# systemctl enable mysqld

[root@web1 mysql]# systemctl status mysqld     #这边出现报错

解决此错误的方法:首先检查环境变量,

[root@web1 etc]# vim /etc/profile #如果有如下的配置,则说明环境变量配置正确

 

 其次检查配置文件/etc/my.cnf中服务器的模块名称是否合适,注意一定是[mysqld],不能写错

 

最后检查是否 /application/mysql/data/support-files/mysql.server 文件的配置错误

经过如上的排查,我们的错误就已经解决

[root@web1 mysql]# systemctl status mysqld
● mysqld.service - MySQL Server by wangju
Loaded: loaded (/etc/systemd/system/mysqld.service; enabled; vendor preset: disabled)
Active: active (running) since 五 2021-07-02 14:50:33 CST; 57min ago
Docs: man:mysql(8)
http://dev.mysql.com/doc/refman/en/using-systemd.html
Main PID: 1188 (mysqld)
Tasks: 28
CGroup: /system.slice/mysqld.service
└─1188 /application/mysql/bin/mysqld --defaults-file=/etc/my.cnf

7月 02 14:50:33 web1 systemd[1]: Started MySQL Server by wangju.

登录到数据库

[root@web1 mysql]# mysql   #登录到数据库
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 2
Server version: 5.7.26 MySQL Community Server (GPL)

Copyright (c) 2000, 2019, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

wangju [(none)]>show databases;       #查看当前的数据库
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
| sys |
+--------------------+
4 rows in set (0.17 sec)

wangju [(none)]>select user();   #查看当前的登录用户
+--------+
| user() |
+--------+
| root@ |
+--------+
1 row in set (0.09 sec)

wangju [(none)]>select user,authentication_string,host from mysql.user;    #查看用户列表命令
+---------------+-------------------------------------------+-----------+
| user | authentication_string | host |
+---------------+-------------------------------------------+-----------+
| root | *5368F3DD951CE4035DA1A7228D7D796D9DF958BD | localhost |
| mysql.session | *THISISNOTAVALIDPASSWORDTHATCANBEUSEDHERE | localhost |
| mysql.sys | *THISISNOTAVALIDPASSWORDTHATCANBEUSEDHERE | localhost |
+---------------+-------------------------------------------+-----------+
3 rows in set (0.30 sec)

wangju [(none)]>quit     #退出数据库
Bye

到这里,数据库就安装好了!

原文地址:https://www.cnblogs.com/luncy/p/14906375.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


本篇内容介绍了“LNMP服务器环境配置实例分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情...
本篇内容主要讲解“OneinStack如何一键安装LNMP”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“OneinStack如何...
小编给大家分享一下如何解决LNMP安装composer install时出现Warning: putenv()问题,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅...
1.源码安装mysql鉴于前边的文章已经详细说过mysql的源码安装可以点击基于LAMP的Discuz论坛的实现(源码安装)自行查看这里为了节省时间用一个shell脚本进行mysql的源码安装用到的mysql依然是5.6.46没有源码包的同学可以点击【mysql-5.6.46.tar.gz提取码:nli5】进行下载
Linux是非常热门的技术,也是当下非常受欢迎的操作系统,具有独特的优势所在,广受大家的喜欢和追捧,今天为大家分享一下几款常用的Linux系统面板,希望对你有所帮助。1、宝塔面板:是一款使用方便、功能强大而且终身免费的服务器管理软件,支持Linux以及Windows系统,一键配置LAMP/LNMP
██【電:131.乀.1418.乀.6667】【薇q:9788.乀.9181】██柬埔寨东方明珠开户目录LAMP1.安装Mariadb2.安装PHP3.测试php和apache的协同4.修改MariaDB数据库配置5.测试数据库连接LNMP(未完待续)LAMP1.安装Mariadb在RaspberryPi中,MySQL无法安装,会自动建议安装Maria
关闭防火墙安装依赖包上传源码包解压源码包,安装nginx启动nginx安装mysql和PHP相关服务修改nginx配置文件,nginx和PHP进行整合重新加载nginx服务启动php-fpm书写PHP测试页测试网页 
一.lnmp的搭建1.准备一台纯净版的虚拟机2.下载Lnmp一键安装包命令:wget http://soft.vpser.net/lnmp/lnmp1.5-full.tar.gz【安装完整版的-推荐1.5版本】也可以本地下载好,通过rz上传:http://soft.vpser.net/lnmp/lnmp1.5-full.tar.gz3.开始安装命令:cdlnmp1.5-full 
1.LNMP理论fastcgi的主要优点:把动态语言和http服务器分离开来,使nginx可以处理静态请求和向后转发动态请求,而php/php-fpm服务器转移解析PHP动态请求使用fastcgi的原因:Nginx不支持对外部动态程序的直接调用或者解析,所有的外部程序(包括PHP)必须通过FastCGI接口来调用。
keepalived高可用keepalived注意:任何软件都可以使用keepalived来做高可用keepalived如何实现高可用VRRP:虚拟路由冗余协议比如公司的网络是通过网关进行上网的,那么如果该路由器故障了,网关无法转发报文了,此时所有人都无法上网了,怎么办?通常做法是给路由器增加一台备节点,但是问
通过阿里云的服务器搭建lnmp架构以及部署wordpress个人博客,连接上域名所遇到的问题及解决办法注释:操作系统centos7.9第一步:购买阿里云ecs服务器,选择系统及其他硬件,下面是我自己购买的配置,可以参考(注意操作系统我购买的时候选错了,后来换成了centos7.9)然后在阿里云“云服
文章目录1.首先了解编译安装和yum安装的区别。2.yum安装准备工作---切换阿里云yum源3.编译安装lnmp**很不建议使用编译安装,麻烦且容易报错。**4.yum安装lnmp**可以先执行一下yumupdate**5.lnmp一键安装[参考网站](https://lnmp.org/)**不喜欢这种方式,所以没测试
电影院系统解压登录mysql创建电影院系统使用的数据库授权账户skyuc访问数据库讲系统部署到www.benet.com网站根目录下mv/usr/src/SKYUC.v3.4.2.SOURCE/wwwroot/*/var/www/benetcom/设置网站根目录所有者和权限客户机测试论坛系统部署解压复制文件到网站根目
下载:​ https://www.php.net/downloads​ https://www.php.net/distributions/php-8.0.6.tar.gz编译安装php:①安装依赖:yum-yinstalllibxml2-develsqlite-develbzip2-devellibcurl-devellibpng-devellibjpeg-develfreetype-devellibicu-develoniguruma-devellibxs
树莓派LNMP关键词:raspberrywebphpdnsmysq1LNMP、LAMP是指一组通常一起使用来运行动态网站或者服务器的自由软件名称首字母缩写,分别指Linux、Nginx/Apache、MySQL和PHP。这里演示如何在树莓派上搭建LNMP环境并配置多个站点。主要内容:树莓派安装nginx树莓派安装ph
官网:http://kodcloud.com/1、准备MySQL数据库 [root@cent8_yzl_20~]#yuminstall-ymysql-server[root@cent8_yzl_20~]#systemctlenable--nowmysqld[root@cent8_yzl_20~]#mysqlmysql>createdatabasekodbox;mysql>createuserkodbox@'10.0.0.
环境应用IP操作系统nginx192.168.122.131centos8mysql192.168.122.132centos8php192.168.122.133centos8准备工作//关闭防火墙#systemctldisable--nowfirewalld#setenforce0#vim/etc/selinux/configSELINUX=disabled安装nginx//安装依
1.购买vps或者外国云主机2.搭建ss服务端3.客户端配置服务端信息,即可。不废话,开始教程:ss-panel-v3简介ss-panel是一套功能齐全的shadowsocks用户管理面板,它可以实现用户注册、用户管理、流量控制、签到、添加多节点、充值购买、邀请返利等诸多功能,是目前网络上使用最广泛的一
LNMP架构数据迁移至NFS第一步:先将原有目录中数据移出数据存储到本地什么位置,获取方法1.通过网站页面右键点击,获取资源地址信息2.find命令利用-mmin53.利用inotify服务监控目录数据变化[root@web01wp-content]#cd/applicationginx/html/blog/wp-content/uploads[root@we
一 点睛业务上线之前最关键的一项任务便是环境部署,往往一个业务涉及多种应用环境,比如Web、DB、PROXY、CACHE等,本示例通过env.roledefs定义不同主机角色,再使用“@roles('webservers')”修饰符绑定到对应的任务函数,实现不同角色主机的部署差异。二 代码#coding=utf-8#!/usr