浏览模式: 标准 | 列表 Tag: linux

解决linux下mysql数据库一直显示使用中问题

当在linuxmysql数据库一直显示使用中,可能这个问题就是数据库权限错误导致。

mysql的数据库用户是mysql,而有时数据库的迁移中因为数据库被root用户直接复制迁移导致权限变成了root用户,所以只需要把权限改为mysql即可。

以wdcp主机管理系统为例,修改一个is36的mysql数据库权限如下:

[root@is36.com /]# chown -R mysql.mysql /www/wdlinux/mysql/var/is36/

Tags: linux, mysql, 使用中

Linux下chkconfig命令详解

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<等级代号>  指定读系统服务要在哪一个执行等级中开启或关毕。

  • 等级0表示:表示关机(不要将此项作为默认设定)
  • 等级1表示:单用户模式
  • 等级2表示:无网络连接的多用户命令行模式,不带NFS
  • 等级3表示:有网络连接的多用户命令行模式,标准的多用户模式
  • 等级4表示:不可用,未定义
  • 等级5表示:带图形界面的多用户模式,X11
  • 等级6表示:重新启动(不要将此项作为默认设定)

需要说明的是,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

修改服务的默认启动等级。

Tags: linux, chkconfig, 运行级别

Linux下多线程下载工具lftp

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"

Tags: linux, 多线程, 下载工具, lftp

Linux下时间同步

只需要两步即可在linux下快速进行时间同步

#yum -y install rdate

#rdate time.nist.gov

Tags: linux, 时间同步

Linux下shell取得字符串行数与指定字符串长度

有某个文本文件is36.txt,需要取得字符串行数指定字符串长度

linuxshell取得字符串行数:

  • cat is36.txt | wc -l

Linux下shell取得指定字符串长度(默认第一行):

  • cat is36.txt | wc -L

Linux下shell取得指定字符串长度(2p即第二行):

  • sed -n '2p' is36.txt | wc -L

Tags: linux, shell, 字符串行数, 指定字符串长度

linux下分割大文件与合并小文件

linux下,如果遇到大文件需要将其分割成若干小文件,而遇到若干小文件需要将其合并成大文件,则需要用到以下命令:

假设需要分割的文件名为file,需要分割为10M一个大小,则命令如下,分割为xaa、xab、xac依次命名的文件。

#split -b 10m file

假设需要合并的小文件名都是xa打头,则命令如下(需要注意的是,合并文件的顺序以dir命令排序出来的顺序合并进去,并且注意待合并的文件时紧跟前一个文件的末尾的……)

#cat xa* >file

Tags: linux, split, cat

CentOS Linux XEN / OpenVZ VPS 增加额外IP

手头有2台vps,分别是基于xenopenvz虚拟化技术,系统为centos linux

需要对他们增加额外的ip,XEN的默认网卡为eth0,OpenVZ的默认网卡为venet0,网卡的配置文件均位于/etc/sysconfig/network-scripts/目录下。

对XEN VPS进行操作如下: 

  • cd /etc/sysconfig/network-scripts/
  • cp ifcfg-eth0  ifcfg-eth0:0
  • vi ifcfg-eth0:0
  • 将其中属于eth0的信息修改为eth0:0然后退出保存
  • ifup eth0:0

eth0一般配置如下: 

  • DEVICE=eth0
  • BOOTPROTO=static
  • ONBOOT=yes
  • IPADDR=111.111.111.111
  • NETMASK=255.255.255.0

对OpenVZ VPS进行操作如下:

OpenVZ VPS有点特别,默认的venet0网卡存放的是ip为127.0.0.1,绑定ipv6地址(如果有),ipv4地址绑定在venet0:0上。以venet0:0为例,增加额外ipv4的ip。 

  • cd /etc/sysconfig/network-scripts/
  • cp ifcfg-venet0:0 ifcfg-venet0:1
  • vi ifcfg-venet0:1
  • 将其中属于venet0:0的信息修改为venet0:1然后退出保存
  • ifup venet0:1

venet0:0一般配置如下:

  • DEVICE=venet0:0
  • ONBOOT=yes
  • IPADDR=222.222.222.222
  • NETMASK=255.255.255.255

Tags: centos, linux, xen, openvz, vps, ip

wdlinux之mysql无法启动解决

某天,连接某VPS时显示程序无法连接mysql服务,SSH登陆进行问题排查。

先查看mysql是否运行:ps auxf | grep mysql

如果有进程存在,那么可以考虑杀死mysql的进程,因为mysql可能已经卡死掉了,命令:kill mysql_pid,然后再尝试启动mysql服务。

当然也可以直接采用pkill -9 mysql这样暴力的杀死进程方式,不过正冰不推荐这样操作,有可能导致数据意外丢失。

本案例中mysql并没运行,那么尝试启动它:service mysqld start

结果并不乐观,返回信息如下: 

  • ERROR! MySQL manager or server PID file could not be found!
  • Starting MySQL. ERROR! Manager of pid-file quit without updating file. 

通过这样的错误提示并不能准确定位问题,继续去看mysql的错误日志文件,位于/www/wdlinux/mysql/var/vps.err,最新的启动错误信息如下: 

  • 120513 14:20:51 mysqld_safe Starting mysqld daemon with databases from /www/wdlinux/mysql-5.1.61/var
  • 120513 14:20:51 [ERROR] /www/wdlinux/mysql-5.1.61/libexec/mysqld: unknown option '--skip-innodb'
  • 120513 14:20:51 [ERROR] Aborting
  • 120513 14:20:51 [Note] /www/wdlinux/mysql-5.1.61/libexec/mysqld: Shutdown complete
  • 120513 14:20:51 mysqld_safe mysqld from pid file /www/wdlinux/mysql-5.1.61/var/vps.pid ended

解决方法很简单了,编辑/www/wdlinux/etc/my.cnf文件,将其中的--skip-innodb注释掉即可,也就是在这个项目前加#并保存,然后启动mysql搞定。

Tags: linux, wdlinux, mysql

Total:20123Next ›