CentOS7安装mysql

发布时间:2026/5/19 23:59:45

CentOS7安装mysql 1、安装工作1.1、卸载 MariaDB1.1.1、MariaDBMySQL 的一个分支主要由开源社区维护。CentOS 7不再默认使用 MySQL 数据库而是 MariaDB 数据库。直接安装 MySQL 会与 MariaDB 的文件冲突。 安装 MySQL 之前先卸载自带的 MariaDB。1.1.2、卸载步骤查看版本有则需要卸载。rpm -qa|grep mariadb卸载复制文件名执行以下指令。rpm -e --nodeps 文件名确认卸载rpm -qa|grep mariadb如图所示1.2、下载资源包Hint将 MySQL 资源包放在/usr/local/下官网下载地址https://downloads.mysql.com/archives/community/下载下来,不要解压1.3、检查旧版本 MySQL指令rpm -qa|grep mysql没有输出说明当前系统没有安装 MySQL开始安装。有输出显示的 MySQL 不是想要的版本则卸载。# 停止服务 systemctl stop mysqld # 卸载 rpm -e --nodeps mysql文件名1.4、解压安装1.4.1 先装上传工具执行这行第一步bash命令yum install -y lrzsz在centos7中使用yum命令时候报错解决方法1.4.2. 执行上传命令第二步bash命令rz弹出窗口后选中你 Windows 里的mysql-8.0.27-linux-glibc2.x-x86_64.tar.xz点打开直接上传到当前/usr/local目录或者更简单直接把 Windows 里的压缩包拖进 MobaXterm 黑色终端自动上传解压tar 指令。我的是tar -Jxvf mysql-8.0.27-linux-glibc2.12-x86_64.tar.xz -C /usr/local/mysql/# .tar.gz 后缀tar-zxvf文件名# .tar.xz 后缀tar-Jxvf文件名​ 解压mysql2.解压完成/usr/local/mysql下会生成 MySQL 文件夹。2、配置工作2.1、基本设置安装完成后的基本设置。2.1.1、文件夹重命名重命名MySQL 文件夹通常命名为mysql版本号# 重命名也可通过Xftp修改mv原文件夹名 mysql8# 软链接ln-s文件夹名 mysql82.1.2、PATH 变量添加 PATH 变量后可在全局使用 MySQL添加方式临时生效export 命令连接会话关闭后失效通常用于测试环境export PATH$PATH:/usr/local/mysql8/bin永久生效修改配置文件。2.1.3、确认安装查看版本mysql--version确定 MySQL 安装成功后可删除压缩包。rm -rf 压缩包名2.2、数据目录2.2.1创建目录mkdir-p/usr/local/mysql/data/mysql8_data在mysql下创建data文件夹里面还有mysql8_data意思是创建一个用来存放 MySQL 数据的文件夹专门存数据库文件。3、初始化 启动3.1、配置文件在/usr/local/etc/下创建my.cnf配置文件用于初始化 MySQL 数据库3.1.1、配置方式注部分配置涉及 MySQL 文件夹名称若文件夹名不是mysql8则需修改。1.修改文件随便一个编辑器2.配置内容[mysql] # 默认字符集 default-character-setutf8mb4 [client] port 3306 socket /tmp/mysql.sock [mysqld] port 3306 server-id 3306 user root socket /tmp/mysql.sock # 安装目录 basedir /usr/local/mysql/mysql8 # 数据存放目录 datadir /usr/local/mysql/data/mysql8_data/ log-bin /usr/local/mysql/data/mysql8_data/mysql-bin innodb_data_home_dir /usr/local/mysql/data/mysql8_data innodb_log_group_home_dir /usr/local/mysql/data/mysql8_data # 日志及进程数据的存放目录 log-error /usr/local/mysql/data/mysql8_data/mysql.log pid-file /usr/local/mysql/data/mysql8_data/mysql.pid # 服务端字符集 character-set-serverutf8mb4 lower_case_table_names1 autocommit 1 ##### 以上涉及文件夹明注意修改 skip-external-locking key_buffer_size 256M max_allowed_packet 1M table_open_cache 1024 sort_buffer_size 4M net_buffer_length 8K read_buffer_size 4M read_rnd_buffer_size 512K myisam_sort_buffer_size 64M thread_cache_size 128 #query_cache_size 128M tmp_table_size 128M explicit_defaults_for_timestamp true max_connections 500 max_connect_errors 100 open_files_limit 65535 binlog_formatmixed binlog_expire_logs_seconds 864000 # 创建表时使用的默认存储引擎 default_storage_engine InnoDB innodb_data_file_path ibdata1:10M:autoextend innodb_buffer_pool_size 1024M innodb_log_file_size 256M innodb_log_buffer_size 8M innodb_flush_log_at_trx_commit 1 innodb_lock_wait_timeout 50 transaction-isolationREAD-COMMITTED [mysqldump] quick max_allowed_packet 16M [myisamchk] key_buffer_size 256M sort_buffer_size 4M read_buffer 2M write_buffer 2M [mysqlhotcopy] interactive-timeout注意这些配置文件里面最好写绝对路径并且写对要不然老报错3.2、初始化初始化命令注意文件夹名称。--defaults-file指定配置文件要放在–initialize 前面--intialize-insecure初始化无密码否则生成随机密码mysqld --defaults-file/usr/local/etc/my.cnf --initialize-insecure3.3、启动 MySQL3.3.1查看是否有这个文件mysqld_safe3.3.2 安全后台启动MySQL# 完整命令 /usr/local/mysql8/bin/mysqld_safe --defaults-file/usr/local/etc/my.cnf # 若添加了PATH变量可省略如下 mysqld_safe --defaults-file/usr/local/etc/my.cnf shell-init: 获取当前目录时出错: getcwd: 无法访问父目录含义当前 shell 的工作目录已被删除比如您之前执行过rm -rf /usr/local/mysql/data/mysql8_data然后仍在那个目录下执行命令。原因您执行mysqld_safe时当前工作目录可能是/usr/local/mysql/data/mysql8_data已经被删除导致 shell 无法获取当前路径。影响对 MySQL 服务本身没有任何影响。mysqld_safe 和 mysqld 都使用绝对路径如配置文件中指定的不会依赖当前目录。只是控制台多了一行无害的错误提示。3.确认启动第二条即 MySQL 服务。ps -ef|grep mysql3.3.3、登录无密码若以--initialize-insecure初始化首次登录时跳过密码。mysql -u root --skip-password有密码若初始化时设置了随机密码在/data/mysql8_data/mysql/mysql.log查看mysql-uroot-pmysql -u root -p Enter password: # 这里什么都不输直接按回车3.4、修改密码3.4.1、首次修改MySQL初始化的 root 用户、新创建的用户都需要设置首次密码。建议使用本地密码插件mysql_native_password。# 修改密码ALTERUSERrootlocalhostIDENTIFIEDWITHmysql_native_passwordBY新密码;# 刷新权限FLUSHPRIVILEGES;3.4.2、平时修改可在 Linux 或 MySQL 中修改。Linux 命令行mysqladmin -u用户名 -p旧密码 password 新密码MySQL 命令行# 设置密码SETPASSWORDFOR用户名主机PASSWORD(‘密码);# 刷新权限FLUSHPRIVILEGES;3.5、退出、关闭服务在 MySQL 命令行中执行若在 Linux 命令行中会退出/关闭 Linux 服务器。3.5.1退出 MySQL命令行quit;exit;3.5.2*关闭 MySQL 服务**shutdown;行**bash mysqladmin-u用户名-p旧密码 password 新密码MySQL 命令行# 设置密码SETPASSWORDFOR用户名主机PASSWORD(‘密码);# 刷新权限FLUSHPRIVILEGES;3.5、退出、关闭服务在 MySQL 命令行中执行若在 Linux 命令行中会退出/关闭 Linux 服务器。3.5.1退出 MySQL命令行quit;exit;3.5.2*关闭 MySQL 服务**shutdown;

相关新闻