【第二章】MySQL数据库基于Centos7.3-部署
一、MySQL数据库的官方网址:
- https://www.mysql.com/
- https://www.oracle.com/
- http://dev.mysql.com/doc/refman/5.7/en/linux-installation.html
- https://dev.mysql.com/downloads/mysql/ //不同版本的安装文档和下载可以在这里找
一键安装参考我的另一篇博客:
【shell 每日一练7】一键安装mysql5.7,以及密码及策略修改
二、MySQL的安装方法:
以下是MySQL常见的三种安装方式:
- 二进制 rpm Yum Repository mysql57-community-release-el7-9.noarch.rpm
- 二进制 预编译 Generic mysql-5.7.19-linux-glibc2.12-x86_64.tar.gz
- 源码包安 Source Code mysql-5.7.19.tar.gz
三、Yum的方法安装MySQL:
- yum安装mysql 5.7 的官方安装方法地址:https://dev.mysql.com/doc/refman/5.7/en/linux-installation-yum-repo.html
1、下载安装包
- 此地址为Mysql 8.0 的安装源其中包含MySQL 5.7的源,可以在后边步骤修改开放的仓库:https://repo.mysql.com//mysql80-community-release-el7-1.noarch.rpm
2、 设置安装初始环境
暂时先把防火墙关闭保证实验顺利:
[root@host- ~]# systemctl stop firewalld
[root@host- ~]# systemctl disable firewalld.service
临时关闭SELlinux:
[root@host- ~]# setenforce
永久关闭SELinux:
[root@host- ~]# sed -ri '/^SELINUX=/c\SELINUX=disabled' /etc/selinux/config
查看SELinux状态:
[root@host- ~]# getenforce
Disabled
3、卸载系统自带的数据库(Centos7自带的是maridb)
可参考:【MySQL解惑笔记】Centos7下卸载彻底MySQL数据库
卸载maridb:
[root@host- ~]# rpm -qa | grep mariadb
mariadb-libs-5.5.-.el7.x86_64
[root@host- ~]# yum -y remove mari*
[root@host- ~]# rm -rf /var/lib/mysql/*
[root@host-131 ~]# rpm -qa | grep mariadb
[root@host-131 ~]#
4、修改仓库
[root@host- src]# yum repolist all |grep mysql //查看所有仓库,并能够看到开启和禁用的仓库
[root@host- src]# yum repolist enabled | grep "mysql.*-community.*" //查看所有开启的仓库,发现现在开启的是MySQL 8.0的,我们需要开启MySQL5.7的仓库
mysql-connectors-community/x86_64 MySQL Connectors Community
mysql-tools-community/x86_64 MySQL Tools Community
mysql80-community/x86_64 MySQL 8.0 Community Server 17 //k
开启和关闭不同仓库,官方提供了三种修改方法:
方法一:使用此方法时候要检测一下自己平台是否支持yum-config-manager命令:
因为系统默认没有安装这个命令,这个命令在yum-utils 包里,可以通过命令yum -y install yum-utils 安装就可以了
shell> sudo yum-config-manager --disable mysql80-community
shell> sudo yum-config-manager --enable mysql57-community 方法二:
shell> sudo dnf config-manager --disable mysql57-community
shell> sudo dnf config-manager --enable mysql56-community 方法三:
我们直接修改Yum源文件:
[root@host- ~]# cd /etc/yum.repos.d
[root@host- yum.repos.d]# vim mysql-community.repo
[mysql57-community]
name=MySQL 5.7 Community Server
baseurl=http://repo.mysql.com/yum/mysql-5.7-community/el/6/$basearch/
enabled= //修改为1表示开启
gpgcheck=
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-mysql [mysql80-community]
name=MySQL 8.0 Community Server
baseurl=http://repo.mysql.com/yum/mysql-8.0-community/el/7/$basearch/
enabled= //修改为0表示关闭
gpgcheck=
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-mysql [root@host- yum.repos.d]# yum repolist enabled | grep "mysql.*-community.*"
mysql-connectors-community/x86_64 MySQL Connectors Community
mysql-tools-community/x86_64 MySQL Tools Community
mysql57-community/x86_64 MySQL 5.7 Community Server 267 //可以看到5.7存储仓库已经开启
注意:我们应该在任何时候只启用一个发布系列的子存储库。当启用多个发布系列的子存储库时,Yum将使用最新的系列。
通过运行以下命令并检查其输出(对于Fedora,用dnf替换yum),验证是否启用了正确的子库并禁用了它:
[root@host- yum.repos.d]# yum repolist enabled | grep mysql
mysql-connectors-community/x86_64 MySQL Connectors Community
mysql-tools-community/x86_64 MySQL Tools Community
mysql57-community/x86_64 MySQL 5.7 Community Server
5、安装MySQL数据库
[root@host- yum.repos.d]# yum -y install mysql-community-server
[root@host- ~]# systemctl start mysqld
[root@host- ~]# systemctl enable mysqld 设置开机自启动
[root@host- ~]# systemctl status mysqld 查看mysql启动状态 [root@host- ~]# ls /var/lib/mysql (安装后可以看到初始化的数据库)
auto.cnf client-cert.pem ibdata1 ibtmp1 mysql.sock.lock public_key.pem sys
ca-key.pem client-key.pem ib_logfile0 mysql performance_schema server-cert.pem
ca.pem ib_buffer_pool ib_logfile1 mysql.sock private_key.pem server-key.pem
6、首次登录数据库,并设置初始化密码
[root@host- ~]# mysql
ERROR (): Access denied for user 'root'@'localhost' (using password: NO)
发现是禁止访问的 在服务器的初始启动时,由于服务器的数据目录为空:服务器初始化。SSL证书和密钥文件是在数据目录中生成的。
安装并启用了validate_password。
一个超级用户帐户'root'@'localhost被创建。
超级用户的密码被设置并存储在错误日志文件中。要显示它,请使用以下命令: MySQL5.5之前版本安装后可以直接登录
MySQL5.5自动生成的密码是空的
MySQL5.6是将密码放在root下的
MySQL5.7是将密码放在:
[root@host- ~]# grep 'temporary password' /var/log/mysqld.log
--30T06::.956716Z [Note] A temporary password is generated for root@localhost: xt8S3rWXOL/C
[root@host- ~]#
[root@host- ~]# mysql -uroot -p"xt8S3rWXOL/C"
mysql: [Warning] Using a password on the command line interface can be insecure.
Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is
Server version: 5.7.22
修改密码:
方法一:
[root@host- ~]# mysqladmin -uroot -p"xt8S3rWXOL/C" password "Yanglt123." //密码要满足复杂性要求
[root@host- ~]# mysql -uroot -p"Yanglt123." 方法二:
[root@host-131 ~]# grep 'temporary password' /var/log/mysqld.log
2018-05-30T06:34:56.956716Z 1 [Note] A temporary password is generated for root@localhost: xt8S3rWXOL/C
[root@host-131 ~]#
[root@host-131 ~]# mysql -uroot -p"xt8S3rWXOL/C"
mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY 'MyNewPass4!';
到此数据库安装成功:
源码安装可参考文章:【Linux运维】LNMP环境配置
【第二章】MySQL数据库基于Centos7.3-部署的更多相关文章
- MySQL性能调优与架构设计——第9章 MySQL数据库Schema设计的性能优化
第9章 MySQL数据库Schema设计的性能优化 前言: 很多人都认为性能是在通过编写代码(程序代码或者是数据库代码)的过程中优化出来的,其实这是一个非常大的误区.真正影响性能最大的部分是在设计中就 ...
- MySQL性能调优与架构设计——第8章 MySQL数据库Query的优化
第8章 MySQL数据库Query的优化 前言: 在之前“影响 MySQL 应用系统性能的相关因素”一章中我们就已经分析过了Query语句对数据库性能的影响非常大,所以本章将专门针对 MySQL 的 ...
- 第二章 Oracle数据库应用
第二章 Oracle数据库应用2.1 表空间和用户权限下管理 2.1.1 表空间 2.1.1.1 分类: 永久性表空间 临时性表空间 ...
- MySQL性能调优与架构设计——第7章 MySQL数据库锁定机制
第7章 MySQL数据库锁定机制 前言: 为了保证数据的一致完整性,任何一个数据库都存在锁定机制.锁定机制的优劣直接应想到一个数据库系统的并发处理能力和性能,所以锁定机制的实现也就成为了各种数据库的核 ...
- MySQL篇,第二章:数据库知识2
MySQL 数据库 2 名词介绍 1.DB(Database) DB就是数据库,存储数据的仓库 2.DBMS(Database Management System) 数据库管理系统 管理数据库的软件, ...
- 第 8 章 MySQL 数据库 Query 的优化
前言: 在之前“影响 MySQL 应用系统性能的相关因素”一章中我们就已经分析过了Query语句对数据库性能的影响非常大,所以本章将专门针对 MySQL 的 Query 语句的优化进行相应的分析. ...
- 第 9 章 MySQL数据库Schema设计的性能优化
前言: 很多人都认为性能是在通过编写代码(程序代码或者是数据库代码)的过程中优化出来的,其实这是一个非常大的误区.真正影响性能最大的部分是在设计中就已经产生了的,后期的优化很多时候所能够带来的改善都只 ...
- 第 7 章 MySQL 数据库锁定机制
前言: 为了保证数据的一致完整性,任何一个数据库都存在锁定机制.锁定机制的优劣直接应想到一个数据库系统的并发处理能力和性能,所以锁定机制的实现也就成为了各种数据库的核心技术之一.本章将对 MySQ ...
- 第二章 MySQL入门篇
第一章 MySQL入门篇 一.MySql简介 简言: 和SQL Server数据库相同,MySQl也是一个关系型数据库管理系统.由瑞典的MySQL AB公司开发,2008年被SUN公司收购,2009年 ...
随机推荐
- Vcenter虚拟化三部曲----SQL Server 2008 R2 数据库安装
操作系统 Windows server 2008 R2 数据库 SQL Server 2008 R2 注意:SQL Server 2008 R2需要操作系统首先安装.NET Frame ...
- EJB到底是什么?---通俗易懂,简单明了
EJB到底是什么? 1. 我们不禁要问,什么是"服务集群"?什么是"企业级开发"? 既然说了EJB 是为了"服务集群"和"企业 ...
- SFTP 服务搭建
1. 介绍 sftp是Secure File Transfer Protocol的缩写,安全文件传送协议.可以为传输文件提供一种安全的加密方法.sftp 与 ftp 有着几乎一样的语法和功能.SFTP ...
- 【Java web 容器resin的安装】
#resin的安装 #启动resin #访问resin监听的java web容器端口 resin修改端口监听号
- 解决webview上移
//解决webview上移 $(".webView").blur(function() { setTimeout(function() { var scrollHeight = d ...
- Node.js http.createServer 简单服务配置
基本实现: var http = require("http"); var server = http.createServer(function (req, res) { if ...
- PHP中的递增/递减运算符
看这段代码 <?php $a=10; $b=++$a; //此语句等同于 ; $a=$a+1 ; $b=$a echo $a."<br>"; echo $b; ? ...
- echo、print、print_r、var_dump
echo(): 可以一次输出多个值,多个值之间用逗号分隔.echo是语言结构(language construct),而并不是真正的函数,因此不能作为表达式的一部分使用. print(): 函数pri ...
- Ubuntu16.04安装TFTP服务,完成开发板下载文件
1.安装TFTP服务 $ sudo apt-get install tftp-hpa tftpd-hpa 2.建立传递目录 $ mkdir tftp $ sudo chmod 777 tftp/ -R ...
- Linux IO多路复用 poll
Linux IO多路复用 poll 之前曾经提到过 select poll 跟select类似,poll改进了select的一个确定,就是poll没有监听上限 不过poll还是需要遍历以及频繁的把数组 ...