编译安装MySQL服务(LAMP2)

目录

1.初始化设置,将安装mysql 所需软件包传到/opt目录下

(1)关闭防火墙

(2)上传软件包到/opt目录

2.安装环境依赖包

3.配置软件模块

4.编译及安装

5.创建mysql用户

6.修改mysql 配置文件

7.更改mysql安装目录和配置文件的属主属组

8.设置路径环境变量

9.初始化数据库

10.添加mysqld系统服务

11.修改mysql 的登录密码

12.授权远程登录


1.初始化设置,将安装mysql 所需软件包传到/opt目录下

(1)关闭防火墙

systemctl stop firewalld.service           #关闭防火墙
setenforce 0                               #关闭selinux防火墙

(2)上传软件包到/opt目录

2.安装环境依赖包

yum -y install gcc gcc-c++ ncurses-devel ncurses bison cmake   #安装软件

  • gcc                                     #C语言的编译器
  • gcc-c++                             #C++的编译器
  • ncurses                             #字符终端下图形互动功能的动态库
  • ncurses-devel                   #ncurses开发包
  • bison                                 #语法分析器
  • cmake                                #mysql需要用cmake编译安装

3.配置软件模块

cd /opt                                              #切换到/opt目录
tar zxvf mysql-boost-5.7.44.tar.gz                   #解压压缩包
cmake \
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
-DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \
-DSYSCONFDIR=/etc \
-DSYSTEMD_PID_DIR=/usr/local/mysql \
-DDEFAULT_CHARSET=utf8  \
-DDEFAULT_COLLATION=utf8_general_ci \
-DWITH_EXTRA_CHARSETS=all \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DMYSQL_DATADIR=/usr/local/mysql/data \
-DWITH_BOOST=boost \
-DWITH_SYSTEMD=1                                               #配置软件模块
  • -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=/usr/local/boost \                                                                                                                     #指定boost的路径,若使用mysql-boost集成包安装则-DWITH_BOOST=boost
  • -DWITH_SYSTEMD=1                                                    #生成便于systemctl管理的文件
     

注意:如果在CMAKE的过程中有报错,当报错解决后,需要把源码目录中的CMakeCache.txt文件删除,然后再重新CMAKE,否则错误依旧

4.编译及安装

make                          #make -j 3  表示开3核同时进行编译
make install

5.创建mysql用户

useradd -M -s /sbin/nologin mysql         #创建mysql用户

6.修改mysql 配置文件

vim /etc/my.cnf                          #修改文件

删除里面的所有配置重新配置

[client]                                                                   #客户端设置

port = 3306

socket = /usr/local/mysql/mysql.sock            

[mysql]                                                                  #服务端设置

port = 3306

socket = /usr/local/mysql/mysql.sock

auto-rehash                                                          #开启自动补全功能

[mysqld]                                                                #服务全局设置

user = mysql                                                         #设置管理用户

basedir=/usr/local/mysql                                      #指定数据库的安装目录

datadir=/usr/local/mysql/data                              #指定数据库文件的存储路径

port = 3306                                                             #指定端口

character-set-server=utf8                                     #设置服务器字符集编码格式为utf8

pid-file = /usr/local/mysql/mysqld.pid                 #指定pid 进程文件路径

socket=/usr/local/mysql/mysql.sock                  #指定数据库连接文件

bind-address = 0.0.0.0                                          #设置监听地址,0.0.0.0代表允许所有,如允许多个IP需空格隔开

skip-name-resolve                                                #禁止域名解析,包括主机名,所以授权的时候要使用 IP 地址

max_connections=4096                                       #设置mysql的最大连接数

default-storage-engine=INNODB                         #指定默认存储引擎

max_allowed_packet=32M                                   #设置在网络传输中一次消息传输量的最大值。系统默认值为 1MB,最大值是 1GB,必须设置 1024 的倍数。

server-id = 1                                                           #指定服务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

sql_mode常用值如下

  • NO_ENGINE_SUBSTITUTION                                                                                                  如果需要的存储引擎被禁用或未编译,那么抛出错误。不设置此值时,用默认的存储引擎替代,并抛出一个异常
  • STRICT_TRANS_TABLES                                                                                                      在该模式下,如果一个值不能插入到一个事务表中,则中断当前的操作,对非事务表不做限制
  • NO_AUTO_CREATE_USER                                                                                                    禁止GRANT创建密码为空的用户
  • NO_AUTO_VALUE_ON_ZERO                                                                                          mysql中的自增长列可以从0开始。默认情况下自增长列是从1开始的,如果你插入值为0的数据会报错
  • NO_ZERO_IN_DATE                                                                                                                不允许日期和月份为零
  • NO_ZERO_DATE                                                                                                                        mysql数据库不允许插入零日期,插入零日期会抛出错误而不是警告
  • ERROR_FOR_DIVISION_BY_ZERO                                                                                      在INSERT或UPDATE过程中,如果数据被零除,则产生错误而非警告。默认情况下数据被零除时MySQL返回NULL
  • PIPES_AS_CONCAT                                                                                                                将"||"视为字符串的连接操作符而非或运算符,这和Oracle数据库是一样的,也和字符串的拼接函数Concat相类似
  • ANSI_QUOTES                                                                                                                        启用ANSI_QUOTES后,不能用双引号来引用字符串,因为它被解释为识别符

7.更改mysql安装目录和配置文件的属主属组

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

8.设置路径环境变量

echo 'export PATH=/usr/local/mysql/bin:/usr/local/mysql/lib:$PATH' >> /etc/profile#在/etc/profile文件追加内容
source /etc/profile                       #生效配置文件

9.初始化数据库

cd /usr/local/mysql/bin/                      #切换目录./mysqld \  
--initialize-insecure \                       #生成初始化密码为空
--user=mysql \                                #指定管理用户
--basedir=/usr/local/mysql \                  #指定数据库的安装目录
--datadir=/usr/local/mysql/data               #指定数据库文件的存储路径

10.添加mysqld系统服务

cp /usr/local/mysql/usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system/	#用于systemctl服务管理
systemctl daemon-reload                     #刷新识别     
systemctl start mysqld.service              #开启服务
systemctl enable mysqld                     #开机自启动
netstat -anpt | grep 3306                   #查看端口,服务是否开启

11.修改mysql 的登录密码

mysqladmin -u root password "abc123" 	     #给root账号设置密码为abc123,原始密码为空

12.授权远程登录

mysql -u root -p                     #授权root用户

grant all privileges on *.* to 'root'@'%' identified by 'abc123';   

                                                 #使用的密码是abc123,并对所有数据库和所有表有操作权限

show databases;                    #查看当前已有的数据库

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/19158.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

JavaScript-JavaWeb

目录 什么是JavaScript? js引入方式 js基础语法 书写语法 变量 数据据类型 运算符 类型转换 流程语句 js函数 js对象 1.Array 2.String 3.JSON js事件监听 什么是JavaScript? ● JavaScript(简称:JS)是一门跨平台、面向对象的脚本语言。是用来控制网页行为的,它能…

2024了,还有人在问为甚死锁?

大家好,我是javapub。 接上篇提到了锁,《InnoDB有哪些锁类型》。这么多的锁,你有遇到过死锁吗? 死锁是在事务数据库中会发生的一种特殊现象,多个事务在执行过程中,相互等待对方持有的资源,导致…

Docker-一文详解容器通信的基础网络模式及衍生的自定义网络模式

启动容器时,通过-p 宿主机端口:容器端口,就可以通过访问宿主机端口访问到容器,这种原理机制是啥,有没有其它方式可以让宿主机和容器通信,以及容器与容器之间如何通信。带着这几个问题开始学习Docker的网络知识。 文章…

【Linux】初识Linux和Linux环境配置

1.什么是Linux操作系统 说到电脑系统 我想有大多数人会脱口而出:windows、mac 是的,这也是如今市场上主流的两种操作系统。 但是对于IT相关的人士来说,还有一种系统也是必须有姓名 那就是Linux Linux,Linux Is Not UniX 的…

PV PVC

默写 1 如何将pod创建在指定的Node节点上 node亲和、pod亲和、pod反亲和: 调度策略 匹配标签 操作符 nodeAffinity 主机 In,NotIn,Exists,DoesNotExist,Gt,Lt podAffinity …

代码随想录-Day23

669. 修剪二叉搜索树 方法一&#xff1a;递归 class Solution {public TreeNode trimBST(TreeNode root, int low, int high) {if (root null) {return null;}if (root.val < low) {return trimBST(root.right, low, high);} else if (root.val > high) {return trimBS…

C语言:从键盘输入若干行字符(每行长度不等),输入后把它们存储到一磁盘文件中。再从该文件中读入这些数据,将其中小写字母转换成大写字母后在显示屏上输出。

void load(char str[100]) {int i 0;FILE* pf fopen("count.txt", "r");if (pf NULL){perror("error:");return 1;}printf("把字符转成大写后\n");while (fscanf(pf,"%s",str)!EOF){for (i 0; str[i] ! \0; i){if (str[…

24V_2A_1.2MHZ|PCD0303升压恒频LCD背光源专用电路超小体积封装

概述 PCD0303是一个恒定频率&#xff0c;6针SOT23电流模式升压转换器用于小型低功耗应用。PCD0303 以1.2MHz切换&#xff0c;并且允许使用微小的&#xff0c;低成本电容器和电感器2mm或更小,内部软启动会产生较小的涌入电流延长电池寿命。PCD0303具有自动切换至轻负载下的脉冲…

磁带存储:“不老的传说”依然在继续

现在是一个数据指数增长的时代&#xff0c;根据IDC数据预测&#xff0c;2025年全世界将产生175ZB的数据。 这里面大部分数据是不需要存储的&#xff0c;在2025预计每年需要存储11ZB的数据。换算个容易理解的说法&#xff0c;1ZB是10^18Bytes, 相当于要写5556万块容量18TB的硬盘…

探数API分享-全球电价一览:谁最高,谁最低?

全球家庭用电价格的平均水平约为0.139美元/千瓦时&#xff0c;这是根据2021年12月的统计数据得出的。在这个平均水平之上&#xff0c;有一些国家的家庭用电价格远超过这个数值&#xff0c;特别是在欧洲的一些发达国家。 丹麦、荷兰、德国、英国、西班牙、比利时等国家的家庭用…

6.S081的Lab学习——Lab5: xv6 lazy page allocation

文章目录 前言一、Eliminate allocation from sbrk() (easy)解析&#xff1a; 二、Lazy allocation (moderate)解析&#xff1a; 三、Lazytests and Usertests (moderate)解析&#xff1a; 总结 前言 一个本硕双非的小菜鸡&#xff0c;备战24年秋招。打算尝试6.S081&#xff0…

快手自动私信获客软件,精准定位潜在客户

在当今数字化营销时代&#xff0c;短视频平台已成为企业与个人品牌不可忽视的流量宝地。快手作为国内领先的短视频社交平台&#xff0c;汇聚了庞大的用户群体和丰富的兴趣社区&#xff0c;为各类商家、创作者提供了无限商机。如何在快手平台上高效引流获客&#xff0c;实现精准…

JAVA-->方法的使用详解

JAVA–>方法的使用详解 1.方法的概念及使用 1.1 什么是方法 : 方法就是一个代码片段. 类似于 C 语言中的 “函数”。 1.2 方法定义 / 方法定义 修饰符 返回值类型 方法名称([参数类型 形参 ...]){方法体代码;[return 返回值]; }判断是否为闰年 public class Method{ //…

JDBC使用步骤-小白入门

一.JDBC开发流程 加载并注册JDBC驱动创建数据库连接创建Statement对象遍历查询结果关闭连接,释放资源 import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.Statement;public class StandardJDBCSample {public static …

opencv进阶 ——(七)图像处理之寸照换背景

寸照换背景&#xff0c;通常指的是将个人证件照片的背景色更换为另一种颜色&#xff0c;如白色、蓝色或红色等&#xff0c;以满足不同用途的要求。例如&#xff0c;护照照片通常要求白色背景&#xff0c;而身份证照片可能需要蓝色背景。这个过程通常涉及到图像处理技术&#xf…

【国产中颖】SH79F9202U单片机驱动LCD段码液晶学习笔记

1. 引言 因新公司之前液晶数显表产品单片机一直用的是 C51单片机(SH79F9202U9)&#xff0c;本人之前没有接触过这款单片机&#xff0c;为了维护老产品不得不重新研究研究这款单片机。 10位ADC LCD的增强型8051微控制器 SH79F9202是一种高速高效率8051可兼容单片机。在同样振…

构造+模拟,CF1148C. Crazy Diamond

一、题目 1、题目描述 2、输入输出 2.1输入 2.2输出 3、原题链接 Problem - 1148C - Codeforces 二、解题报告 1、思路分析 题目提示O(5n)的解法了&#xff0c;事实上我们O(3n)就能解决&#xff0c;关键在于1&#xff0c;n的处理 我们读入数据a[]&#xff0c;代表初始数组…

继电器的选型和英应用

如何保证信号的稳定&#xff1f; 怎么消除继电器触点的电弧&#xff1f; 危害&#xff1a; 继电器的触点在动作时容易产生电弧&#xff0c;电弧具有热效应容易导致触点烧蚀粘接&#xff0c;缩短继电器的寿命&#xff0c;并且产生电弧的过程中会对外进行电磁辐射&#xff0c;…

GoFly框架快速新增接口/上手写代码

拿到一个新框架大家可能无从下手&#xff0c;因为你对框架设计思路、结构不了解&#xff0c;从而产生恐惧&#xff0c;所以我们框架是通过简单可视化界面安装&#xff0c;安装后即可看到效果&#xff0c;然后点击先点点看各个功能&#xff0c;看现有的功能是怎么写的&#xff0…

【错误记录】HarmonyOS 运行报错 ( Failure INSTALL_PARSE_FAILED_USESDK_ERROR )

文章目录 一、报错信息二、问题分析三、解决方案 一、报错信息 在 DevEco Studio 中 , 使用 远程设备 , 向 P40 Failure[INSTALL_PARSE_FAILED_USESDK_ERROR] compileSdkVersion and releaseType of the app do not match the apiVersion and releaseType on the device. 二、…