linux的服务器需要做的操作

centos6.5下:
修改默认字符集为 zh_CN.UTF-8,如果没有中文语言包可能需要安装中文语言包支持
[root@meinv01 ~]# yum groupinstall chinese-support
[root@meinv01 ~]# cat /etc/sysconfig/i18n #<==修改此配置文件为如下
LANG="zh_CN.UTF-8"
SYSFONT="latarcyrheb-sun16"
[root@meinv01 ~]# source /etc/sysconfig/i18n
[root@meinv05 ~]# date #<==验证
2018年 12月 21日 星期五 19:22:43 CST

centos7.5系统:

与centos6.5不太一样,需要做以下操作调整字符集为 zh_CN.UTF-8

[root@meinv05 ~]# locale -a|grep zh_CN*        #<==查看当前系统是否安装中文语言包
zh_CN
zh_CN.gb18030
zh_CN.gb2312
zh_CN.gbk
zh_CN.utf8

如果没有安装中文语言包,使用以下2条命令中其中一条安装中文语言包即可

[root@meinv05 ~]# yum install -y kde-l10n-Chinese
[root@meinv05 ~]# yum groupinstall -y "fonts"
[root@meinv05 ~]# locale -a|grep zh_CN* #<=再次查看确保系统已安装下列中文语言包
zh_CN
zh_CN.gb18030
zh_CN.gb2312
zh_CN.gbk
zh_CN.utf8
[root@meinv05 ~]# echo $LANG #<==查看当前字符集
en_US.UTF-8
[root@meinv05 ~]# vi /etc/locale.conf #<=编辑配置文件修改默认的英文字符集为以下
LANG="zh_CN.UTF-8"
[root@meinv05 ~]# cat /etc/locale.conf
LANG="zh_CN.UTF-8"
[root@meinv05 ~]# source /etc/locale.conf
[root@meinv05 ~]# locale
LANG=zh_CN.UTF-8
LC_CTYPE="zh_CN.UTF-8"
LC_NUMERIC="zh_CN.UTF-8"
LC_TIME="zh_CN.UTF-8"
LC_COLLATE="zh_CN.UTF-8"
LC_MONETARY="zh_CN.UTF-8"
LC_MESSAGES="zh_CN.UTF-8"
LC_PAPER="zh_CN.UTF-8"
LC_NAME="zh_CN.UTF-8"
LC_ADDRESS="zh_CN.UTF-8"
LC_TELEPHONE="zh_CN.UTF-8"
LC_MEASUREMENT="zh_CN.UTF-8"
LC_IDENTIFICATION="zh_CN.UTF-8"
LC_ALL=
[root@meinv05 ~]# date #<==验证
2018年 12月 21日 星期五 19:22:43 CST

MySQL数据库需要做的操作

1.编译安装MySQL时,指定MySQL数据库默认的字符集为zh_CN.UTF-8,使用到的参数如下:

-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci \
-DEXTRA_CHARSETS=gbk,gb2312,utf8,ascii \

2.修改MySQL数据库配置文件 /etc/my.cnf 中相关参数

[root@meinv05 ~]# cat /etc/my.cnf          #<==注意此修改不能使用echo追加的方法,因为此配置文件是对应模块的,echo追加对于修改不生效
[client] #<==在[client]字段里加入default-character-set=utf8
default-character-set=utf8 #<==如果使用mysqlbinlog命令查看log-bin日志出错,可把此行注释掉或者删除不加此行
[mysqld] #<==在[mysqld]字段里加入character-set-server=utf8(MySQL5.5版本以上使用)
port = 3306 #<==在[mysqld]字段里加入default-character-set=utf8(MySQL5.1版本以下使用)
socket = /var/lib/mysql/mysql.sock
character-set-server=utf8
[mysql] #<==在[mysql]字段里加入default-character-set=utf8
no-auto-rehash
default-character-set=utf8

注意:修改完成后,重启mysql服务就生效(如果仅仅是修改MySQL客户端就无需重启服务直接生效),[mysqld]字段与[mysql]字段是有区别的,一起更改。

进入MySQL命令行界面下,验证字符集是否全部是 zh_CN.UTF-8

mysql> show variables like 'character_set%';
+--------------------------+-------------------------------------------+
| Variable_name | Value |
+--------------------------+-------------------------------------------+
| character_set_client | utf8 |
| character_set_connection | utf8 |
| character_set_database | utf8 |
| character_set_filesystem | binary |
| character_set_results | utf8 |
| character_set_server | utf8 |
| character_set_system | utf8 |
| character_sets_dir | /application/mysql-5.5.32/share/charsets/ |
+--------------------------+-------------------------------------------+
8 rows in set (0.00 sec)

小结

  1. 字符串显示乱码的罪魁祸首是字符集不统一,最大程度上规避乱码问题要注意以下几点
  2. Linux服务器字符集,Linux服务器的链接终端,MySQL客户端/服务端(编译安装,二进制解压,yum,创建库和表等),开发的程序所有的字符集都需要统一
  3. 生产环境业务上线前统一好字符集,尽量避免字符集不统一造成的乱码
  4. MySQL数据库统一字符集,如有特殊需求,使用单独MySQL数据库或者使用MySQL多实例区分特殊字符集的程序

centos6.5和centos7.5统一字符集为zh_CN.UTF-8解决系统和MySQL数据库乱码问题的更多相关文章

  1. MySQL字符集设置—MySQL数据库乱码问题

    MySQL(4.1以后版本) 服务器中有六个关键位置使用了字符集的概念,他们是:client .connection.database.results.server .system.MySQL有两个字 ...

  2. centos6.5和centos7如何搭建php环境

    作者:白狼 出处:http://www.manks.top/linux_php.html 本文版权归作者,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责 ...

  3. Centos6.5和Centos7 php环境搭建如何实现呢

    首先我们先查看下centos的版本信息 代码如下: #适用于所有的linux lsb_release -a#或者cat /etc/redhat-release#又或者rpm -q centos-rel ...

  4. 在my.ini文件中配置mysql统一字符集

    测试的mysql版本为:5.7.14 查看mysql字符集命令: show variables like 'character_set_%'; 以下是在my.ini文件中配置mysql统一字符集参数: ...

  5. {MySQL数据库初识}一 数据库概述 二 MySQL介绍 三 MySQL的下载安装、简单应用及目录介绍 四 root用户密码设置及忘记密码的解决方案 五 修改字符集编码 六 初识sql语句

    MySQL数据库初识 MySQL数据库 本节目录 一 数据库概述 二 MySQL介绍 三 MySQL的下载安装.简单应用及目录介绍 四 root用户密码设置及忘记密码的解决方案 五 修改字符集编码 六 ...

  6. MySQL数据库指定字符集

    mysql 创建数据库时指定编码很重要,很多开发者都使用了默认编码,但是我使用的经验来看,制定数据库的编码可以很大程度上避免倒入导出带来的乱码问题. 我们遵循的标准是,数据库,表,字段和页面或文本的编 ...

  7. centos7 mysql数据库的安装与使用

    一:数据库的安装 第一步 下载数据库到主机,, 第二步 通过xshell将数据库压缩包上传至centos7虚拟主机(#注意:服务器主机需下载上传工具lrzsz   命令:yun -y install ...

  8. centos7环境配置haproxy实现mysql数据库和redis代理服务器

    centos7环境配置haproxy实现mysql数据库代理 我们通常会碰到这样的业务场景: b主机和c数据库在同一个内网,a主机不能直接访问c数据库,我们可以通过在b主机上搭建代理让a访问c数据库, ...

  9. (转)修改及查看mysql数据库的字符集

    原文:http://www.cnblogs.com/donqiang/articles/2057972.html Liunx下修改MySQL字符集:1.查找MySQL的cnf文件的位置find / - ...

随机推荐

  1. Webpack实战(五):轻松读懂Webpack如何分离样式文件

    在上一篇文章中我给大家分享了预处理器(loader),里面讲到了style-loader 和css-loader,有关样式引入的问题,但是上面的样式文件只是引入到style标签里面,并不是我想要的样式 ...

  2. Nginx. 用http访问https跨域

    用http 访问 https域名, 报跨越问题 解决方法: 在nginx相应服务的转发配置下添加: add_header 'Access-Control-Allow-Origin' 'http://i ...

  3. poj-1753题题解思路

    今天天气很好! 首先题意是这样的:: 翻盖游戏是在一个长方形的4x4场上进行的,其16个方格中的每一个都放置了双面的棋子.每一块的一边是白色的,另一边是黑色的,每一块都是躺着的,要么是黑色的,要么是白 ...

  4. L1和L2:损失函数和正则化

    作为损失函数 L1范数损失函数 L1范数损失函数,也被称之为最小绝对值误差.总的来说,它把目标值$Y_i$与估计值$f(x_i)$的绝对差值的总和最小化. $$S=\sum_{i=1}^n|Y_i-f ...

  5. axios请求方法封装.

    axios的使用上一般封装好对应的方法,ES6导出,直接调用,消息通知使用了ElementUI的Message组件. 这是一个封装了axios的Rest风格的工具类,包扩常用的POST,GET,PUT ...

  6. Chrome浏览器所有页面全部崩溃解决办法。

    今晚写代码的时候更新了一下Chrome,结果打开所有网页都提示 喔唷 崩溃了,而且找到c盘内没有bd0001.sys文件,电脑内也无任何百度系的软件,此解决办法pass. 折腾了半天从google中找 ...

  7. 双指针,BFS和图论(三)

    (一)图论 1.大臣的旅费 很久以前,T王国空前繁荣. 为了更好地管理国家,王国修建了大量的快速路,用于连接首都和王国内的各大城市. 为节省经费,T国的大臣们经过思考,制定了一套优秀的修建方案,使得任 ...

  8. LXC(LinuX Container)之namespaec和cgroup

    LXC(LinuX Container)之namespaec和cgroup namespace概述 从操作系统级上实现了资源的隔离,它本质上是宿主机上的进程(容器进程),所以资源隔离主要就是指进程资源 ...

  9. Static、Final、static final

    Static.Final.static final final可以修饰:属性,方法,类,局部变量(方法中的变量) 用final关键字修饰的变量,只能进行一次赋值操作,并且在生存期内不可以改变它的值. ...

  10. 笔记常用Linux命令(三) 查看服务器日志

    服务器日志 用于记录服务器的运行情况 查看服务器日志 tail:查看后面几行 n 显示行数 f 持续侦测后面的内容,查看服务器日志常用 查看最新的服务日志(静态) 命令格式:tail -n 行数 日志 ...