CentOS7安装配置mysql5.7 tar免安装版「建议收藏」

CentOS7安装配置mysql5.7 tar免安装版「建议收藏」一、CentOS7.4系统自带mariadb # 查看系统自带的Mariadb [root@localhost~]# rpm -qa|grep mariadb mariadb-libs-5.5.44…

一、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

代码100分

二、检查mysql是否存在

# 检查mysql是否存在

代码100分[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 

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

代码100分[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

CentOS7安装配置mysql5.7 tar免安装版「建议收藏」 

CentOS7安装配置mysql5.7 tar免安装版「建议收藏」

五、上传第四步下载的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
log=/data_disk/mysql/logs/mysql.log
long_query_time=3
log-slow-queries=/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/mysqld

添加开机启动服务

[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 Server
   Loaded: loaded (/etc/systemd/system/mysqld.service; disabled; vendor preset: disabled)
   Active: active (running) since Fri 2019-11-15 18:08:33 CST; 5min ago
     Docs: man:mysqld(8)
           http://dev.mysql.com/doc/refman/en/using-systemd.html
  Process: 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.pid

Nov 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/mysqld.log

flush privileges

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

(0)
上一篇 2022-12-18
下一篇 2022-12-19

相关推荐

  • 如何搭建数据库自动化运维体系框架_大数据平台搭建与运维

    如何搭建数据库自动化运维体系框架_大数据平台搭建与运维
    需求背景: 随着业务的增长、对运维效率和质量的要求不断提高,对自动化运维体系的需求也不断增强。 目前笔者服务的很多中大型企业客户,运维其实还停留在“刀耕火种…

    2023-04-06
    164
  • Percona-XtraDB

    Percona-XtraDBPXC(Percona-XtraDB-Cluster)5.7版本集群部署 Centos 7.3系统部署Mysql 集群 PXC三个节点分别执行和安装(1)配置hosts cat /etc/h

    2022-12-29
    142
  • Python嵌套定义:高效组织代码结构的秘诀

    Python嵌套定义:高效组织代码结构的秘诀Python是一种面向对象的编程语言,使用类(class)的概念进行代码组织。其中,类中可以包含方法(method),方法中可以包含变量(variable)、循环、条件判断、其他方法等。此外,Python中还引入了嵌套定义的概念,即将一个函数或方法定义在另一个函数或方法中。嵌套定义的使用可以减少全局变量的使用、实现代码模块的封装、提高代码的可读性等优点。

    2024-01-18
    97
  • sql注入漏洞修复方法_注入sql注入

    sql注入漏洞修复方法_注入sql注入
    我们都是善良的银!一生戎码只为行侠仗义,知道这个不是为了做啥非法的事,只是知道小偷怎么偷东西才能更好地防范。 SQL注入(SQL Injection),指将…

    2023-04-08
    152
  • MySQL8.0 新特性 Hash Join「建议收藏」

    MySQL8.0 新特性 Hash Join「建议收藏」概述&背景 MySQL一直被人诟病没有实现HashJoin,最新发布的8.0.18已经带上了这个功能,令人欣喜。有时候在想,MySQL为什么一直不支持HashJoin呢?我想可能是因为MySQ

    2022-12-23
    175
  • MySQL查询的同时更改数据

    MySQL查询的同时更改数据1、今天遇到查询的同时修改数据 业务场景:字段表中的数据,在主表中冗余,刚开始是不保存字典的名称字段,后为了查询方便冗余主表字段。在后台维护数据用此sql UPDATE budg_project_f…

    2023-04-11
    165
  • mysql如何处理重复数据?让你的效率更高效的方法_数据有效率怎么计算

    mysql如何处理重复数据?让你的效率更高效的方法_数据有效率怎么计算有时候,数据表中会存在相同的记录。在获取表中记录时,相较于取得重复记录来说,取得唯一的记录显然更有意义。那么关于mysql数据库如何处理重复数据呢,下面就为大家来讲解这个问题。

    2023-03-31
    161
  • 用户画像产品化——从零开始搭建实时用户画像(六)

    用户画像产品化——从零开始搭建实时用户画像(六)在开发好用户标签以后,如何将标签应用到实际其实是一个很重要的问题。只有做好产品的设计才能让标签发挥真正的价值,本文将介绍用户画像的产品化过程。 一、标签展示 首先是标签展示功能,这个主要供业务人员和研

    2023-03-16
    156

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注