zoukankan      html  css  js  c++  java
  • 数据库介绍1MySQL安装

    第1章 数据库介绍及mysql安装

     

    1.1 数据库简介

      数据库,简而言之可视为电子化的文件柜——存储电子文件的处所,用户可以对文件中的数据运行新增、截取、更新、删除等操作。

      所谓“数据库”系以一定方式储存在一起、能予多个用户共享、具有尽可能小的冗余度、与应用程序彼此独立的数据集合。

    1.1.1 什么是数据

      数据是指对客观事件进行记录并可以鉴别的符号,是对客观 事物的性质、状态以及相互关系等进行记载的物理符号或这些物 理符号的组合。它是可识别的、抽象的符号。

    1.1.2 数据库管理系统

    非关系型数据库

      NoSQL:非关系型数据库(Not only SQL)

    不是否定关系型数据库,做关系型数据库的的补充。
    想做老大,先学会做老二。

     

    关系型数据库

      关系型数据库的特点

    二维表
    典型产品 Oracle传统企业,MySQL是互联网企业
    数据存取是通过SQL(结构化查询语句)
    最大特点,数据安全性方面强(ACID) 

    1.1.3 NoSQL特性总览

      l  不是否定关系型数据库,而是作为补充,现在也有部分替代的趋势。

      l  关注高性能,高并发,灵活性,忽略和上述无关的功能。

      l  现在也在提升安全性和使用功能。

      l  典型产品:Redis(持久化缓存,两个半天)、MongoDB(最接近关系型数据 的NoSQL)、Memcached。

      l  管理不适用SQL管理,而是用一些特殊的 API 或 数据接口。

    1.1.4 NoSQL的分类、特点、典型产品

      键值(KV)存储:Memcached、Redis

      列存储(column-oriented):HBASE(新浪,360)、Cassandra(200台服务器集群 )

      文档数据库(document-oriented):MongoDB(最接近关系型数据库的NoSQL)

      图形存储(Graph):Neo4j

        数据来源: https://db-engines.com/en/ranking

    1.2 数据库相关产品

    1.2.1 Oracle公司产品介绍

      Oracle数据库版本介绍

        7--8i--9i--10g—11g--12c--18c(?)

      Oracle的市场应用

        a)  市场份额第一,趋势递减

        b)  市场空间,传统企业

        c)  传统企业也在互联网化

      MySQL数据库版本介绍

        5.0--5.1--5.5--5.6--5.7--8.0

      MySQL的市场应用

        a)  中、大型互联网公司

        b)  市场空间:互联网领域第一

        c)  趋势明显

        d)  同源产品:MariaDB、perconaDB

    1.2.2 其他公司产品

      微软:SQL Server

    微软和sysbase合作开发的产品,后来自己开发,windows平台
    3,4线小公司,传统行业在用

      IBM :DB2数据库

          市场占有量小

          目前只有:国有银行(人行、中国银行、工商银行等)、中国移动应用。

    下面三者广泛应用在大型互联网公司

      PostgreSQL
      MongoDB
      Redis

    1.3 Mysql简介

    1.3.1 mysql数据库发展史

    1 1979年,报表工具Unireg出现。
    2 1985 年,以瑞典David Axmark 为首,成立了一家公司(AB前身),IASM引擎出现。
    3 1990年,提供SQL支持。
    4 1999-2000年,MySQL AB公司成立,并公布源码,开源化。
    5 2000年4月BDB引擎出现,支持事务。
    6 2008年1月16日,Sun(太阳微系统)正式收购MySQL。
    7 2009年4月20日,甲骨文公司宣布以每股9.50美元,74亿美元的总额收购Sun电脑公司,MySQL 转入Oracle 门下。
    8 2013年6月18日,甲骨文公司修改MySQL授权协议,移除了GPL。但随后有消息称这是一个bug。

    1.3.2 MySQL的特点简介

      开源、社区版免费、简单,使用方便,可靠、稳定、安全、社区活跃

    1.3.3 mysql产品线的介绍

    mysql产品线(主线)

      3.26--5.2版本

        – 正宗后代

        – Centos5、6中默认有5.1版本

        – Centos7中默认是MariaDB

      5.4--5.7 ,8.0版本

        – 借鉴社区好的贡献,进一步开发的版本

        – 主流版本:5.5 5.6 5.7

      MySQL Cluster 6.0 版本&更高

        – 类似于Oracle RAC,硬件要求高。

        – 一般各大网站没有人用

             mysql产品线(派生产品)

                      派生版本有Drizzle、MariaDB、Percona Server及OurDelta等。

    1.3.4 企业生产场景选择MySQL数据库建议:

    1) 稳定版:选择开源的社区版的稳定版GA版本 
    2) 产品线:可以选择5.1或5.5 互联网公司主流5.5,其次是5.1和5.6 
    3) 选择MySQL数据库GA版发布后6个月以上的GA版本。 
    4)要选择前后几个月没有大的BUG修复的版本,而不是大量修复BUG的集中版本 
    5)最好向后较长时间没有更新发布的版本 
    6)要考虑开发人员开发程序使用的版本是否兼容你选的版本 
    7)作为内部开发人员开发测试数据库环境,跑大概3-6个月的事件 
    8)优先企业非核心业务采用新版本的数据库GA版本软件 
    9)向DBA高手请教,或者在及技术氛围好的群里和大家一起交流,使用真正的高手们用过的好用的GA版本产品
    10)若是没有重要的功能BUG或性能瓶颈,则可以开始考虑作为任何任务数据服务的后端数据库软件

    1.4 mysql数据库的安装

    1.4.1 系统环境说明

    [root@db02 ~]# cat /etc/redhat-release 
    CentOS release 6.9 (Final)
    [root@db02 ~]# uname -r
    2.6.32-696.el6.x86_64
    [root@db02 ~]# /etc/init.d/iptables status
    iptables: Firewall is not running.
    [root@db02 ~]# getenforce 
    Disabled
    [root@db02 ~]# hostname  -I 
    10.0.0.52 172.16.1.52

    1.4.2 mysql编译安装

      安装依赖包

    yum  install  -y  ncurses-devel libaio-devel

      安装cmake编译工具

      cmake

      定制功能:存储引擎、字符集、压缩等

      定制安装位置、数据存储位置、文件位置(socket)

    yum install cmake -y

      创建mysql管理用户

    useradd -s /sbin/nologin -M mysql -u1000
    id mysql

      下载mysql软件包,解压

    mkdir  -p /server/tools 
    cd /server/tools
    wget -q http://mirrors.sohu.com/mysql/MySQL-5.6/mysql-5.6.36.tar.gz
    tar xf mysql-5.6.36.tar.gz

             注:这里使用的是sohu的镜像源进行下载(软件版本5.6.36)

        官方下载方式参考:http://www.cnblogs.com/clsn/p/8025324.html#_label4

    进入查询目录,使用cmake进行编译,安装,创建软连接,过程时间较长。

    cd mysql-5.6.36
    cmake . -DCMAKE_INSTALL_PREFIX=/application/mysql-5.6.36 \
    -DMYSQL_DATADIR=/application/mysql-5.6.36/data \
    -DMYSQL_UNIX_ADDR=/application/mysql-5.6.36/tmp/mysql.sock \
    -DDEFAULT_CHARSET=utf8 \
    -DDEFAULT_COLLATION=utf8_general_ci \
    -DWITH_EXTRA_CHARSETS=all \
    -DWITH_INNOBASE_STORAGE_ENGINE=1 \
    -DWITH_FEDERATED_STORAGE_ENGINE=1 \
    -DWITH_BLACKHOLE_STORAGE_ENGINE=1 \
    -DWITHOUT_EXAMPLE_STORAGE_ENGINE=1 \
    -DWITH_ZLIB=bundled \
    -DWITH_SSL=bundled \
    -DENABLED_LOCAL_INFILE=1 \
    -DWITH_EMBEDDED_SERVER=1 \
    -DENABLE_DOWNLOADS=1 \
    -DWITH_DEBUG=0
    make && make install
    ln -s /application/mysql-5.6.36/ /application/mysql

    1.4.3 数据库安装后的操作

      复制配置文件

    \cp  /application/mysql/support-files/my-default.cnf /etc/my.cnf

      编译的MySQL可以暂时不需要设置配置文件。

      注意:如果以前操作系统中安装过rpm格式的mysql,系统中可能会遗留/etc/my.cnf文件,我们需要将它删除掉

    初始化数据库

    /application/mysql/scripts/mysql_install_db --basedir=/application/mysql/ --datadir=/application/mysql/data --user=mysql

      防止报错:数据库启动会提示,找不到xx/tmp/mysql.sock,原因是5.6.36版本不会自动创建tmp目录,需要我们手工创建。

    mkdir /application/mysql/tmp

      修改程序目录的属主,属组

    chown -R mysql.mysql /application/mysql/

      复制启动脚本,并修改权限

    cp support-files/mysql.server /etc/init.d/mysqld
    chmod 700 /etc/init.d/mysqld

      添加环境变量,使用mysql命令

    echo 'PATH=/application/mysql/bin/:$PATH' >>/etc/profile
    tail -1 /etc/profile
    source /etc/profile
    echo $PATH
    mysql

    1.4.4 数据库安全设置

      设置root用户密码

    mysqladmin -u root password '123456'
    mysql -uroot -p123456

      优化数据库(清理用户及无用数据库)

    select user,host from mysql.user;
    drop user ''@'db02';
    drop user ''@'localhost';
    drop user 'root'@'db02';
    drop user 'root'@'::1';
    select user,host from mysql.user;
    drop database test;
    show databases;

    1.5 mysql 5.7版本安装说明

      主机系统环境说明

    [root@db13 ~]# cat /etc/redhat-release
    CentOS release 6.9 (Final)
    [root@db13 ~]# uname -r
    2.6.32-696.el6.x86_64
    [root@db13 ~]# getenforce
    Disabled
    [root@db13 ~]# /etc/init.d/iptables status
    iptables: Firewall is not running.
    [root@db13 ~]# hostname -I
    10.0.0.153 172.16.1.153

      获取软件(采用二进制包方式进行安装)

    mkdir -p /server/tools
    cd /server/tools
    wget http://mirrors.sohu.com/mysql/MySQL-5.7/mysql-5.7.17-linux-glibc2.5-x86_64.tar.gz

      解压

    tar xf mysql-5.7.17-linux-glibc2.5-x86_64.tar.gz

      将软件移动到程序目录,创建软连接

    mkdir -p /application/
    mv mysql-5.7.17-linux-glibc2.5-x86_64 /application/mysql-5.7.17
    ln -s /application/mysql-5.7.17 /application/mysql

      添加mysql用户,并进行授权

    useradd -M -s /sbin/nologin  -u 1000 mysql
    chown -R mysql.mysql /application/mysql-5.7.17

      初始化数据库

    /application/mysql-5.7.17/bin/mysqld --initialize --user=mysql --basedir=/application/mysql-5.7.17 --datadir=/application/mysql-5.7.17/data

             初始化时注意最后一行输出root密码

    2017-12-13T08:40:31.760309Z 1 [Note] A temporary password is generated for root@localhost: )*1E7=fYd&>i

      拷贝配置文件和启动文件

    \cp /application/mysql-5.7.17/support-files/my-default.cnf /etc/my.cn
    \cp \application/mysql-5.7.17/support-files/mysql.server /etc/init.d/mysqld

    # 修改启动文件内容(配置目录)

      将程序安装到 /usr/local/ 下 可以省略这步操作

    sed 's#/usr/local#/application#g' /application/mysql-5.7.17/bin/mysqld_safe /etc/init.d/mysqld -i

      启动mysql

    [root@db13 tools]# /etc/init.d/mysqld start 
    Starting MySQL.Logging to '/application/mysql/data/db13.err'.
     SUCCESS! 
    [root@db13 tools]# /etc/init.d/mysqld status
     SUCCESS! MySQL running (1509)

      添加环境变量

    echo 'PATH=/application/mysql/bin/:$PATH' >>/etc/profile
    tail -1 /etc/profile
    source /etc/profile
    echo $PATH

    修改mysql密码

    [root@db13 tools]# mysqladmin -uroot -p password 123456
    Enter password: 【输入初始化时生成的密码】
    mysqladmin: [Warning] Using a password on the command line interface can be insecure.
    Warning: Since password will be sent to server in plain text, use ssl connection to ensure password safety.
  • 相关阅读:
    Web Service接口设计(转)
    DataTable绑定到GridView时,RowDataBound事件
    SQLiteHelper
    SQL FOR XML子句的各种用法
    公历转农历函数
    SQL里变量的声明以及常用函数举例
    Python 与 Matlab混合语言编程资料
    Iterator和Generator学习心得(二)转
    python26 调用mysql 5.1
    转:程序员能力矩阵
  • 原文地址:https://www.cnblogs.com/coolpale/p/8414318.html
Copyright © 2011-2022 走看看