热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Mysql5.7.34数据库源码编译安装

Mysql数据库源码编译安装MySQL是一个关系型数据库管理系统,关系型数据库是将数据保存在不同的表中,而非将所有数据放在一个大仓库内,这样就加快了速度并提高了灵活性。由于其体积小

Mysql 数据库源码编译安装

MySQL是一个关系型数据库管理系统,关系型数据库是将数据保存在不同的表中,而非将所有数据放在一个大仓库内,这样就加快了速度并提高了灵活性。由于其体积小、速度快、总体拥有成本低,尤其是开放源码这一特点,一般中小型网站的开发都选择MySQL作为网站数据库。

环境准备:``

安装环境 Centos 7.9

内核版本 Linux 3.10.0-1160.e17.x86_64 x86_64

数据库版本信息 mysql5.7.34

推荐:硬盘至少大于20G,内存至少3G,SWAP3G(内存空间不足在编译安装时会导致编译安装失败)

安装准备:

1.检查卸载默认

rpm –qa|grep mariadb

rpm -e --nodeps 现有版本

列出当前mysql rpm 安装包

rpm –qa|grep mysql

卸载命令如上述

一、下载、编译安装

编译安装流程:

1.下载关联依赖

yum -y install gcc gcc-devel gcc-c++ gcc-c++-devel autoconf* automake* zlib* libxmlncurses-devel ncurses libgcrypt libtool* cmake openssl openssl-devel bisonbison-devel perl-Data-Dumper boost boost-doc boost-devel

yum install ncurses-devel (字符终端处理库)

yum install bison (linux 下c/c++语法分析器)

2.创建用户、用户组及安装目录

groupadd mysql

useradd -p mysql -s /sbin/nologin mysql

mkdir -pv /usr/local/mysql/conf 创建2级目录/mysql/conf

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

mkdir -pv /data/mysql_data 创建数据库存放数据目录

chown -R mysql:mysql /data/mysql_data

3.下载相应源码包

cd /usr/local/src/tools/ (选定文件下载目录,自选)

进入官网找到下载对应版本信息()



找到对应版本后可直接下载到本机(服务器无网状态推荐)

从物理机上获取mysql源码文件(推荐使用第三方远程工具上传到服务器指定目录)

服务器能连接外网可直接使用命令下载,如下:

wget 对应版本

4.解压文件夹到指定位置

cd /usr/local/src/tools/ (自定义存放文件位置)

tar –zxvf mysql-boost-5.7.34.tar.gz –C /usr/local/mysql/

解压完成后进入解压后的文件目录

cd /usr/local/mysql/

cd mysql-boost-5.7.34

5.编译

cmake

-DCMAKE_INSTALL_PREFIX=/usr/local/mysql \ 指定安装目录

-DMYSQL_DATADIR=/data/mysql_data \ 数据库存放目录

-DSYSCOnFDIR=/usr/local/mysql/conf \

-DMYSQL_UNIX_ADDR=/data/mysql_data/mysql.sock

-DSYSTEMD_PID_DIR=/usr/local/mysql

-DMYSQL_USER=mysql

-DWITH_SYSTEMD=1

-DWITH_MYISAM_STORAGE_ENGINE=1

-DWITH_INNOBASE_STORAGE_ENGINE=1 \ innodb 存储引擎

-DWITH_ARCHIVE_STORAGE_ENGINE=1

-DWITH_MEMORY_STORAGE_ENGINE=1

-DWITH_READLINE=1

-DMYSQL_TCP_PORT=3306

-DENABLED_LOCAL_INFILE=1

-DENABLE_DOWNLOADS=1

-DEXTRA_CHARSETS=all \ 安装所有扩展字符集

-DDEFAULT_CHARSET=utf8mb4 \ 使用 utf8 字符

-DDEFAULT_COLLATION=utf8mb4_general_ci \ 校检字符

-DWITH_DEBUG=0

-DMYSQL_MAINTAINER_MODE=0

-DWITH_SSL:STRING=system

-DWITH_ZLIB:STRING=bundled

-DDOWNLOAD_BOOST=1

-DWITH_BOOST=./boost

如在编译过程中出现错误信息需删除当前目录下cMakCache.txt文件,解决错误信息后重新编译

以下显示表示编译完成

6.编译安装

make -j$(cat /proc/cpuinfo| grep "processor"| wc -l) && make install (会显示的当前编译进度时间较长)

-j参数后数字为CPU核数,可以通过使用cat /proc/ cpuinfo | grep processor | wc –l 进行查看使用该命令可提高编译速度

注: 建议直接使用make && make install 编译安装(多次编译错误运行此条)

编译成功显示如下

7.配置启动文件

cd ./mysql-5.7.30

cp ./scripts/mysqld.service /usr/lib/systemd/system

vi /usr/lib/systemd/system/mysqld.service

无需修改

8.添加环境变量

cat > /etc/profile.d/mysql.sh <
PATH=/usr/local/mysql/bin:$PATH

export PATH

EOF

source /etc/profile 运行该命令使其生效

9.初始化数据库

参数说明,之前版本在/usr/local/mysql/script目录下的初始化程序mysql_install_db本版本已移除,转而使用mysqld替代。

-–initialize 会生成一个随机密码(保存在~/.mysql_secret),而 -–initialize-insecure 不会生成密码。

-–datadir目标目录下不能有数据文件。

初始化命令

rm -fr /data/mysql_data/*

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

10.启动服务

systemctl enable mysqld.service 设置mysql开机自启动

systemctl daemon-reload 重新加载配置

systemctl start mysqld.service 启动mysql数据库

systemctl status mysqld.service 检查当前数据库状态

查看当前进程状态

ps –ef|grep mysql


二、检查登录数据库

安装完成后运行命令可检查数据库版本

/usr/local/mysql/bin/mysql --version

查看mysql安装完成后目录

登录数据库、初始无密码


三、卸载源码安装

停用服务

systemctl stop mysqld.service

先执行此,才能禁用服务

systemctl daemon-reload

在开机时禁用一个服务

systemctl disable mysqld.service

删除环境变量文件

rm /etc/profile.d/mysql.sh

删除systemd启动文件mysqld.service

rm /usr/lib/systemd/system/mysqld.service

删除安装目录

rm -rf /usr/local/mysql

删除数据文件(可选)

rm -rf /data/mysql_data/*



推荐阅读
  • Linux服务器密码过期策略、登录次数限制、私钥登录等配置方法
    本文介绍了在Linux服务器上进行密码过期策略、登录次数限制、私钥登录等配置的方法。通过修改配置文件中的参数,可以设置密码的有效期、最小间隔时间、最小长度,并在密码过期前进行提示。同时还介绍了如何进行公钥登录和修改默认账户用户名的操作。详细步骤和注意事项可参考本文内容。 ... [详细]
  • 如何在服务器主机上实现文件共享的方法和工具
    本文介绍了在服务器主机上实现文件共享的方法和工具,包括Linux主机和Windows主机的文件传输方式,Web运维和FTP/SFTP客户端运维两种方式,以及使用WinSCP工具将文件上传至Linux云服务器的操作方法。此外,还介绍了在迁移过程中需要安装迁移Agent并输入目的端服务器所在华为云的AK/SK,以及主机迁移服务会收集的源端服务器信息。 ... [详细]
  • Centos下安装memcached+memcached教程
    本文介绍了在Centos下安装memcached和使用memcached的教程,详细解释了memcached的工作原理,包括缓存数据和对象、减少数据库读取次数、提高网站速度等。同时,还对memcached的快速和高效率进行了解释,与传统的文件型数据库相比,memcached作为一个内存型数据库,具有更高的读取速度。 ... [详细]
  • linux6.5 配置邮件服务,centos 6.5服务器搭建邮件服务postfix和dovecot
    centos6.5搭建邮件服务postfix和dovecot------------------------------------------------安装DNS指定邮件交换记 ... [详细]
  • Nginx使用AWStats日志分析的步骤及注意事项
    本文介绍了在Centos7操作系统上使用Nginx和AWStats进行日志分析的步骤和注意事项。通过AWStats可以统计网站的访问量、IP地址、操作系统、浏览器等信息,并提供精确到每月、每日、每小时的数据。在部署AWStats之前需要确认服务器上已经安装了Perl环境,并进行DNS解析。 ... [详细]
  • 本文介绍了Python高级网络编程及TCP/IP协议簇的OSI七层模型。首先简单介绍了七层模型的各层及其封装解封装过程。然后讨论了程序开发中涉及到的网络通信内容,主要包括TCP协议、UDP协议和IPV4协议。最后还介绍了socket编程、聊天socket实现、远程执行命令、上传文件、socketserver及其源码分析等相关内容。 ... [详细]
  • Linux如何安装Mongodb的详细步骤和注意事项
    本文介绍了Linux如何安装Mongodb的详细步骤和注意事项,同时介绍了Mongodb的特点和优势。Mongodb是一个开源的数据库,适用于各种规模的企业和各类应用程序。它具有灵活的数据模式和高性能的数据读写操作,能够提高企业的敏捷性和可扩展性。文章还提供了Mongodb的下载安装包地址。 ... [详细]
  • CentOS 7部署KVM虚拟化环境之一架构介绍
    本文介绍了CentOS 7部署KVM虚拟化环境的架构,详细解释了虚拟化技术的概念和原理,包括全虚拟化和半虚拟化。同时介绍了虚拟机的概念和虚拟化软件的作用。 ... [详细]
  • Centos7搭建ELK(Elasticsearch、Logstash、Kibana)教程及注意事项
    本文介绍了在Centos7上搭建ELK(Elasticsearch、Logstash、Kibana)的详细步骤,包括下载安装包、安装Elasticsearch、创建用户、修改配置文件等。同时提供了使用华为镜像站下载安装包的方法,并强调了保证版本一致的重要性。 ... [详细]
  • Linux下安装免费杀毒软件ClamAV及使用方法
    本文介绍了在Linux系统下安装免费杀毒软件ClamAV的方法,并提供了使用该软件更新病毒库和进行病毒扫描的指令参数。同时还提供了官方安装文档和下载地址。 ... [详细]
  • Apache Shiro 身份验证绕过漏洞 (CVE202011989) 详细解析及防范措施
    本文详细解析了Apache Shiro 身份验证绕过漏洞 (CVE202011989) 的原理和影响,并提供了相应的防范措施。Apache Shiro 是一个强大且易用的Java安全框架,常用于执行身份验证、授权、密码和会话管理。在Apache Shiro 1.5.3之前的版本中,与Spring控制器一起使用时,存在特制请求可能导致身份验证绕过的漏洞。本文还介绍了该漏洞的具体细节,并给出了防范该漏洞的建议措施。 ... [详细]
  • 在Windows10系统上使用VMware创建CentOS虚拟机的详细步骤教程
    本文详细介绍了在Windows10系统上使用VMware创建CentOS虚拟机的步骤,包括准备条件、安装VMware、下载CentOS ISO文件、创建虚拟机并进行自定义配置、设置虚拟机的ISO与网络、进行安装和配置等。通过本文的指导,读者可以轻松地创建自己的CentOS虚拟机并进行相应的配置和操作。 ... [详细]
  • LINUX学习之centos7营救模式
    今天卸载软件的时候,不小心把GNOME的一些组件给卸了,导致桌面无法正常开启,会卡在启动过程中,而我的开机启动模式又是设置为图形界面,所以一开LINUX就卡住了,进入不了命令行界面 ... [详细]
  • 在单位的一台4cpu的服务器上部署了esxserver,挂载了6个虚拟机,目前运行正常。在安装部署过程中,得到了cnvz.net论坛精华区 ... [详细]
  • systemd-nspawn可以创建最轻量级的容器(ns的意思就是namespace),本文的实验平台是Ubuntu16.04,x86_64机器。本文的目的是:在Ubuntu中用syst ... [详细]
author-avatar
手机用户2502877051
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有