CentOS7安装配置mysql5.7 tar免安装版

2024-09-09 18:08

本文主要是介绍CentOS7安装配置mysql5.7 tar免安装版,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、CentOS7.4系统自带mariadb

# 查看系统自带的Mariadb
[root@localhost~]# rpm -qa|grep mariadb
mariadb-libs-5.5.44-2.el7.centos.x86_64
# 卸载系统自带的Mariadb
[root@localhost ~]# rpm -e --nodeps mariadb-libs-5.5.44-2.el7.centos.x86_64
# 删除etc目录下的my.cnf
[root@localhost ~]# rm /etc/my.cnf

二、检查mysql是否存在

# 检查mysql是否存在

[root@localhost ~]# rpm -qa | grep mysql
[root@localhost~]# 


三、查看用户和组是否存在

1)检查mysql组合用户是否存在

# 检查mysql组和用户是否存在,如无则创建

[root@localhost~]# cat /etc/group | grep mysql 
[root@localhost~]# cat /etc/passwd | grep mysql 

# 查询全部用户(只是做记录,没必要执行) 

[root@localhost ~]# cat /etc/passwd|grep -v nologin|grep -v halt|grep -v shutdown|awk -F ":" '{print $1 "|" $3 "1" $4}' | more 
root|010
sync|510
lyt|100011000

2)若不存在,则创建mysql组和用户 

# 创建mysql用户组
[root@localhost~]# groupadd mysql
# 创建一个用户名为mysql的用户,并加入mysql用户组
[root@localhost~]# useradd -g mysql mysql
# 制定password 为mysql
[root@localhost~]# passwd mysql
Changing password for user mysql.
New password: 
BAD PASSWORD: The password is a palindrome
Retype new password: 
passwd: all authentication tokens updated successfully.

四、下载mysql的tar包

https://dev.mysql.com/downloads/mysql/5.7.html#downloads

 

五、上传第四步下载的mysql TAR包到

# 进入/usr/local/src文件夹
[root@localhost ~]# cd /usr/local/src/
# 上传mysql TAR包
# 解压tar文件
[root@localhost src]# tar xvf mysql-5.7.28-el7-x86_64.tar
# 解压mysql-5.7.28-el7-x86_64.tar.gz
[root@localhost src]# tar -zxvf mysql-5.7.28-el7-x86_64.tar.gz
# 解压后的文件移动到/usr/local文件夹
[root@localhost src]# mv mysql-5.7.28-el7-x86_64 /usr/local/mysql5.7

六、更改所属的组和用户

# 更改所属的组和用户
[root@localhost local]# chown -R mysql mysql5.7/
[root@localhost local]# chgrp -R mysql mysql5.7/
# 创建数据和日志存储目录
[root@localhost mysql5.7]# cd /data_disk/mysql
[root@localhost mysql]# mkdir data
[root@localhost mysql]# mkdir logs
# 修改所有者
[root@localhost mysql]# chown -R mysql:mysql data

七、在/etc下创建my.cnf文件

# 进入/etc文件夹下
[root@localhost mysql]# cd /etc
# 编辑my.cnf
[root@localhost etc]# vim my.cnf 

1)my.cnf添加如下内容:

[mysql]
# 设置mysql客户端默认字符集
default-character-set=utf8 [mysqld]
# 设置3306端口
port = 3306 
# 设置mysql的安装目录
basedir=/usr/local/mysql5.7
# 设置mysql数据库的数据的存放目录
datadir=/data_disk/mysql/data
# 日志的相关配置
log-error=/data_disk/mysql/logs/error.log
# 不建议开日志,所有的操作都记录文件太大
# general-log=1
# log-output=FILE
# general-log-file=/data_disk/mysql/logs/mysql.log
slow_query_log=1
long_query_time=3
slow_query_log_file=/data_disk/mysql/logs/slowquery.log
# 允许最大连接数
max_connections=200
# 服务端使用的字符集默认为8比特编码的latin1字符集
character-set-server=utf8
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB 
lower_case_table_names=1
max_allowed_packet=16M

八、进入mysql文件夹,并安装mysql

[root@localhost bin]# ./mysqld --initialize --user=mysql --basedir=/usr/local/mysql5.7 --datadir=/data_disk/mysql/data

九、设置开机启动

创建软连接

ln -s /usr/local/mysql5.7/bin/mysqld /usr/bin/mysqld
ln -s /usr/local/mysql5.7/bin/mysqld /usr/sbin/mysqldln -s /usr/local/mysql5.7/bin/mysql /usr/bin/mysql
ln -s /usr/local/mysql5.7/bin/mysql /usr/sbin/mysql

添加开机启动服务

[root@localhost bin]# vim /etc/systemd/system/mysqld.service

复制粘贴以下内容:

[Unit]
Description=MySQL Server
Documentation=man:mysqld(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
Type=forking
PIDFile=/data_disk/mysql/mysqld.pid
# Disable service start and stop timeout logic of systemd for mysqld service.
TimeoutSec=0
# Execute pre and post scripts as root
PermissionsStartOnly=true
# Start main service
ExecStart=/usr/sbin/mysqld --daemonize --pid-file=/data_disk/mysql/mysqld.pid $MYSQLD_OPTS
# Sets open_files_limit
LimitNOFILE = 5000
Restart=on-failure
RestartPreventExitStatus=1
PrivateTmp=false

注意:ExecStart配置成自己的路径 

启动mysql服务

[root@localhost logs]# systemctl start mysqld
[root@localhost logs]# systemctl status mysqld
● mysqld.service - MySQL ServerLoaded: loaded (/etc/systemd/system/mysqld.service; disabled; vendor preset: disabled)Active: active (running) since Fri 2019-11-15 18:08:33 CST; 5min agoDocs: man:mysqld(8)http://dev.mysql.com/doc/refman/en/using-systemd.htmlProcess: 10770 ExecStart=/usr/sbin/mysqld --daemonize --pid-file=/data_disk/mysql/mysqld.pid $MYSQLD_OPTS (code=exited, status=0/SUCCESS)Main PID: 10772 (mysqld)CGroup: /system.slice/mysqld.service└─10772 /usr/sbin/mysqld --daemonize --pid-file=/data_disk/mysql/mysqld.pidNov 15 18:08:33 localhost.localdomain systemd[1]: Starting MySQL Server...
Nov 15 18:08:33 localhost.localdomain systemd[1]: Started MySQL Server.

如果启动失败,首先应该查看/data_disk/mysql/logs目录下的错误日志

,如果没有特别明显的,可以是selinux或者权限的问题

永久关闭selinux

[root@localhost logs]# vim /etc/selinux/config

设置SELINUX=disabled 

十、重置root密码查看随机生成的密码

[root@localhost logs]# vim /data_disk/mysql/logs/error.log

flush privileges

这篇关于CentOS7安装配置mysql5.7 tar免安装版的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1151893

相关文章

mybatis映射器配置小结

《mybatis映射器配置小结》本文详解MyBatis映射器配置,重点讲解字段映射的三种解决方案(别名、自动驼峰映射、resultMap),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定... 目录select中字段的映射问题使用SQL语句中的别名功能使用mapUnderscoreToCame

Linux下MySQL数据库定时备份脚本与Crontab配置教学

《Linux下MySQL数据库定时备份脚本与Crontab配置教学》在生产环境中,数据库是核心资产之一,定期备份数据库可以有效防止意外数据丢失,本文将分享一份MySQL定时备份脚本,并讲解如何通过cr... 目录备份脚本详解脚本功能说明授权与可执行权限使用 Crontab 定时执行编辑 Crontab添加定

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版

Vite 打包目录结构自定义配置小结

《Vite打包目录结构自定义配置小结》在Vite工程开发中,默认打包后的dist目录资源常集中在asset目录下,不利于资源管理,本文基于Rollup配置原理,本文就来介绍一下通过Vite配置自定义... 目录一、实现原理二、具体配置步骤1. 基础配置文件2. 配置说明(1)js 资源分离(2)非 JS 资

MySQL8 密码强度评估与配置详解

《MySQL8密码强度评估与配置详解》MySQL8默认启用密码强度插件,实施MEDIUM策略(长度8、含数字/字母/特殊字符),支持动态调整与配置文件设置,推荐使用STRONG策略并定期更新密码以提... 目录一、mysql 8 密码强度评估机制1.核心插件:validate_password2.密码策略级

ShardingProxy读写分离之原理、配置与实践过程

《ShardingProxy读写分离之原理、配置与实践过程》ShardingProxy是ApacheShardingSphere的数据库中间件,通过三层架构实现读写分离,解决高并发场景下数据库性能瓶... 目录一、ShardingProxy技术定位与读写分离核心价值1.1 技术定位1.2 读写分离核心价值二

QT Creator配置Kit的实现示例

《QTCreator配置Kit的实现示例》本文主要介绍了使用Qt5.12.12与VS2022时,因MSVC编译器版本不匹配及WindowsSDK缺失导致配置错误的问题解决,感兴趣的可以了解一下... 目录0、背景:qt5.12.12+vs2022一、症状:二、原因:(可以跳过,直奔后面的解决方法)三、解决方

SpringBoot路径映射配置的实现步骤

《SpringBoot路径映射配置的实现步骤》本文介绍了如何在SpringBoot项目中配置路径映射,使得除static目录外的资源可被访问,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一... 目录SpringBoot路径映射补:springboot 配置虚拟路径映射 @RequestMapp

RabbitMQ 延时队列插件安装与使用示例详解(基于 Delayed Message Plugin)

《RabbitMQ延时队列插件安装与使用示例详解(基于DelayedMessagePlugin)》本文详解RabbitMQ通过安装rabbitmq_delayed_message_exchan... 目录 一、什么是 RabbitMQ 延时队列? 二、安装前准备✅ RabbitMQ 环境要求 三、安装延时队