MySQL部署及编译安装

一、数据库的基本概念

(1)、数据:
描述事物的符号记录称为:数据data
包括数字、文字、图形、图像、声音、档案记录等;
以“记录”形式按统一的格式进行存储

(2)、表:
将不同的记录组织在一起,就形成了“表”;
是用来存储具体数据的

(3)、数据库:
数据库就是表的集合,是存储数据库的仓库;
以一定的组织方式存储的互相有关的数据

二、关系数据库

(1)关系数据库:
1、是基于关系模型的数据库系统,它的基本概念来自于关系模型。
2、关系模型建立在关系代数的理论基础上,数据结构使用简单易懂的二维数据表,可以用简单的 “实体-关系” (E -R)图来直接表示。

3、E - R 图中包含了实体(数据对象)、关系和属性三个要素。

  • 实体:实例
  • 属性:实体所具有的某一特性,一个实物可以有多个属性;
  • 联系:实体集之间的对应关系成为联系,也称关系
    (2)、非关系数据库:
    1、非关系数据库不以关系模型为依据,不需要固定的表格式,它有以下有点:
  • 数据库高并发读写的需求
  • 对海量数据库高效率储存与访问
  • 数据库的高扩展性与高可用性的需求
    2、储存方式:键-值方式(key-value)
    以键为依据存储、删、改数据
    3、非关系数据库产品
    Memcached 是一个开源的。高新能的、具有分布式内存对象的缓存系统,以 key-value 方式存储数据,有以下特点:
    • 缓存数据以减轻数据库压力并能加快访问速度;
    • 加速动态 Web 应用;
    • 缓存的内容保存在内存中

redis 也是典型的 以 key-value 方式存储数据的,具有以下特点:

  • 支持内存缓存;
  • 支持持久化;
  • 数据类型更多;
  • 支持集群、分布式;
  • 支持队列
    (3)、MySQL数据库介绍
  • Oracle 旗下产品;
    • 遵守了 GPL协议,可以免费试用与修改;
  • 特点:
    性能优越,服务稳定
    开源、无版本限制、成本低
    多线程、多用户
    基于C/S(客户端/服务端)架构
    安全可靠

三、安装MySQL

环境准备

1、安装编译工具

yum -y install \
ncurses \
ncurses-devel \
bison \
cmake \
gcc \
gcc-c++ 

2、创建用户

useradd -s /sbin/nologin  mysql

3、解压压缩包**

tar zxvf mysql-5.7.17.tar.gz -C /opt/
tar zxvf boost_1_59_0.tar.gz -C /usr/local/

为方便使用对boost_1_59_0.tat.gz进行重命名

mv boost_1_59_0 boost

4、cmake
cd mysql-5.7.17/

cmake \
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
-DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \
-DSYSCONFDIR=/etc \
-DSYSTEMD_PID_DIR=/usr/local/mysql \
-DDEFAULT_CHARSET=utf8  \
-DDEFAULT_COLLATION=utf8_general_ci \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_ARCHIVE_STORAGE_ENGINE=1 \
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
-DWITH_PERFSCHEMA_STORAGE_ENGINE=1 \
-DMYSQL_DATADIR=/usr/local/mysql/data \
-DWITH_BOOST=/usr/local/boost \
-DWITH_SYSTEMD=1

5、编译安装

make && make install

6、授权和修改配置文件**
(1)、授权

chown -R mysql.mysql /usr/local/mysql/

(2)修改配置文件
vi /etc/my.cnf ,删除文件中原有内容,再添加以下代码:

[client]
port = 3306
default-character-set=utf8
socket = /usr/local/mysql/mysql.sock

[mysql]
port = 3306
default-character-set=utf8
socket = /usr/local/mysql/mysql.sock

[mysqld]
user = mysql
basedir = /usr/local/mysql
datadir = /usr/local/mysql/data
port = 3306
character_set_server=utf8
pid-file = /usr/local/mysql/mysqld.pid
socket = /usr/local/mysql/mysql.sock
server-id = 1

sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_AUTO_VALUE_ON_ZERO,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,PIPES_AS_CONCAT,ANSI_QUOTES

7 、添加权限和修改环境变量

chown mysql:mysql /etc/my.cnf

修改环境变量

echo 'PATH=/usr/local/mysql/bin:/usr/local/mysql/lib:$PATH' >> /etc/profile
echo 'export PATH' >> /etc/profile

source /etc/profile    //使环境变量生效

8、初始化数据库
cd /usr/local/mysql/

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

9、方便管理,可以将 mysql 服务复制到 system 目录下,方便操作

cp /usr/local/mysql/usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system/

10、开启mysql服务

systemctl daemon-reload
systemctl start mysql 

为mysql数据库创建密码

mysqladmin -u root -p password "abc123" //给root账号设置密码为abc123提示输入的是原始密码。
mysql -u root -p

授权远程登录

grant all privileges on *.* to 'root'@'%' identified by 'abc123' with grant option;
//允许任何远程终端登录
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值