当在linux下mysql数据库一直显示使用中,可能这个问题就是数据库权限错误导致。
mysql的数据库用户是mysql,而有时数据库的迁移中因为数据库被root用户直接复制迁移导致权限变成了root用户,所以只需要把权限改为mysql即可。
以wdcp主机管理系统为例,修改一个is36的mysql数据库权限如下:
[root@is36.com /]# chown -R mysql.mysql /www/wdlinux/mysql/var/is36/
记录一个IT技术员的生活与技术
Written by 正冰 on 2014, June 1, 4:34 PM
当在linux下mysql数据库一直显示使用中,可能这个问题就是数据库权限错误导致。
mysql的数据库用户是mysql,而有时数据库的迁移中因为数据库被root用户直接复制迁移导致权限变成了root用户,所以只需要把权限改为mysql即可。
以wdcp主机管理系统为例,修改一个is36的mysql数据库权限如下:
[root@is36.com /]# chown -R mysql.mysql /www/wdlinux/mysql/var/is36/
Written by 正冰 on 2014, April 24, 10:08 PM
chkconfig命令主要用来更新(启动或停止)和查询系统服务的运行级信息。谨记chkconfig不是立即自动禁止或激活一个服务,它只是简单的改变了符号连接。
chkconfig [--add][--del][--list][系统服务] 或 chkconfig [--level <等级代号>][系统服务][on/off/reset]
chkconfig在没有参数运行时,显示用法。如果加上服务名,那么就检查这个服务是否在当前运行级启动。如果是,返回true,否则返回false。如果在服务名后面指定了on,off或者reset,那么chkconfi 会改变指定服务的启动信息。on和off分别指服务被启动和停止,reset指重置服务的启动信息,无论有问题的初始化脚本指定了什么。on和off开关,系统默认只对运行级3,4,5有效,但是reset可以对所有运行级有效。
--add 增加所指定的系统服务,让chkconfig指令得以管理它,并同时在系统启动的叙述文件内增加相关数据。
--del 删除所指定的系统服务,不再由chkconfig指令管理,并同时在系统启动的叙述文件内删除相关数据。
--level<等级代号> 指定读系统服务要在哪一个执行等级中开启或关毕。
需要说明的是,level选项可以指定要查看的运行级而不一定是当前运行级。对于每个运行级,只能有一个启动脚本或者停止脚本。当切换运行级时,init不会重新启动已经启动的服务,也不会再次去停止已经停止的服务。
chkconfig --list [name]:显示所有运行级系统服务的运行状态信息(on或off)。如果指定了name,那么只显示指定的服务在不同运行级的状态。
chkconfig --add name:增加一项新的服务。chkconfig确保每个运行级有一项启动(S)或者杀死(K)入口。如有缺少,则会从缺省的init脚本自动建立。
chkconfig --del name:删除服务,并把相关符号连接从/etc/rc[0-6].d删除。
chkconfig [--level levels] name:设置某一服务在指定的运行级是被启动,停止还是重置。
每个被chkconfig管理的服务需要在对应的init.d下的脚本加上两行或者更多行的注释。第一行告诉chkconfig缺省启动的运行级以及启动和停止的优先级。如果某服务缺省不在任何运行级启动,那么使用 - 代替运行级。第二行对服务进行描述,可以用\ 跨行注释。
例如,random.init包含三行:
# chkconfig: 2345 20 80
# description: Saves and restores system entropy pool for \
# higher quality random number generation.
chkconfig --list #列出所有的系统服务
chkconfig --add httpd #增加httpd服务
chkconfig --del httpd #删除httpd服务
chkconfig --level httpd 2345 on #设置httpd在运行级别为2、3、4、5的情况下都是on(开启)的状态
chkconfig --list #列出系统所有的服务启动情况
chkconfig --list mysqld #列出mysqld服务设置情况
chkconfig --level 35 mysqld on #设定mysqld在等级3和5为开机运行服务,--level 35表示操作只在等级3和5执行,on表示启动,off表示关闭
chkconfig mysqld on #设定mysqld在各等级为on,“各等级”包括2、3、4、5等级
1.服务脚本必须存放在/etc/ini.d/目录下;
2.chkconfig --add servicename
在chkconfig工具服务列表中增加此服务,此时服务会被在/etc/rc.d/rcN.d中赋予K/S入口了
3.chkconfig --level 35 mysqld on
修改服务的默认启动等级。
Written by 正冰 on 2014, March 22, 7:31 PM
在linux下一般用wget下载文件,但是wget是单线程下载工具,无法满足某些需求。
Linux下多线程下载工具lftp解决了这个问题,下面我以CentOS为例,简单说一下lftp的功能。
安装lftp:
yum -y install lftp
使用lftp(20线程下载文件):
lftp -c "pget -n 20 http://blog.is36.com/pack.zip"
Written by 正冰 on 2013, May 21, 9:50 AM
Written by 正冰 on 2013, January 29, 8:21 AM
有某个文本文件is36.txt,需要取得字符串行数与指定字符串长度。
Linux下shell取得指定字符串长度(默认第一行):
Linux下shell取得指定字符串长度(2p即第二行):
Written by 正冰 on 2012, August 3, 6:27 PM
在linux下,如果遇到大文件需要将其分割成若干小文件,而遇到若干小文件需要将其合并成大文件,则需要用到以下命令:
假设需要分割的文件名为file,需要分割为10M一个大小,则命令如下,分割为xaa、xab、xac依次命名的文件。
#split -b 10m file
假设需要合并的小文件名都是xa打头,则命令如下(需要注意的是,合并文件的顺序以dir命令排序出来的顺序合并进去,并且注意待合并的文件时紧跟前一个文件的末尾的……)
#cat xa* >file
Written by 正冰 on 2012, May 31, 9:10 AM
手头有2台vps,分别是基于xen与openvz虚拟化技术,系统为centos linux。
需要对他们增加额外的ip,XEN的默认网卡为eth0,OpenVZ的默认网卡为venet0,网卡的配置文件均位于/etc/sysconfig/network-scripts/目录下。
对XEN VPS进行操作如下:
eth0一般配置如下:
对OpenVZ VPS进行操作如下:
OpenVZ VPS有点特别,默认的venet0网卡存放的是ip为127.0.0.1,绑定ipv6地址(如果有),ipv4地址绑定在venet0:0上。以venet0:0为例,增加额外ipv4的ip。
venet0:0一般配置如下:
Written by 正冰 on 2012, May 13, 2:37 PM
某天,连接某VPS时显示程序无法连接mysql服务,SSH登陆进行问题排查。
先查看mysql是否运行:ps auxf | grep mysql
如果有进程存在,那么可以考虑杀死mysql的进程,因为mysql可能已经卡死掉了,命令:kill mysql_pid,然后再尝试启动mysql服务。
当然也可以直接采用pkill -9 mysql这样暴力的杀死进程方式,不过正冰不推荐这样操作,有可能导致数据意外丢失。
本案例中mysql并没运行,那么尝试启动它:service mysqld start
结果并不乐观,返回信息如下:
通过这样的错误提示并不能准确定位问题,继续去看mysql的错误日志文件,位于/www/wdlinux/mysql/var/vps.err,最新的启动错误信息如下:
解决方法很简单了,编辑/www/wdlinux/etc/my.cnf文件,将其中的--skip-innodb注释掉即可,也就是在这个项目前加#并保存,然后启动mysql搞定。