MySQL字符集LATIN1转UTF8

导出表结构

mysqldump -uroot -p --default-character-set=utf8 -d databasename > db.sql
修改db.sql内的字符集设置(notepad++编辑)
ENGINE=MyISAM DEFAULT CHARSET=latin1;
修改为
ENGINE=MyISAM DEFAULT CHARSET=utf8;
导出数据
mysqldump -uroot -p --quick --no-create-info --extended-insert --default-character-set=latin1 databasename >data.sql
修改data.sql
set names latin1;
改为
set names utf8;//使得客户端和链接使用utf8格式,使得数据以utf8的形式存储

创建数据库

create database databasename default charset utf8;

导入表结构

mysql -uroot -p databasename < db.sql

导入表数据

mysql -uroot -p databasename < data.sql

备注:原理流程
1、导出表结构,把latin1结构替换成utf8
2、用原有的latin1导出数据,并且将set names替换成utf8格式
3、创建数据库,默认字符集改成utf8
4、导入表结构、数据

debian7基本操作学习笔记

由于一开始就随大流投入了centos+apache温暖的怀抱,对debian和nginx–尤其是后者–一窍不通,这也影响了我后面的一些选择,比如桌面版用fedora,树莓派用pidora。

本着生命的本质在于折腾的原则,决定学习一下debian和nginx。不过不会很深入,毕竟不是真的要做运维。

debian的基本操作:

和centos最大的不同在于包管理。

apt-get update只能软件库同步,不能安装

apt-get install 安装

apt-get remove 删除 继续阅读debian7基本操作学习笔记

fedora18安装HP打印机

f18hp

我心目中将Fedora系统定位为办公系统,因为能满足我一切的办公需要。而WIN7则定位为娱乐系统,因为游戏太多。

安装libreoffice之后首先遇到的问题就是文档打印问题,fedora系统刚安装时系统自动安装了插件,并且也能正常识别打印机,但是按了打印没反应。

试过按照http://hplipopensource.com网站的指引下载了hplip-3.12.11.run并且进行了安装,但是总是在hp-setup一步联网下载ppd时无果,尝试过几次之后放弃。

然后通过http://openprinting.org/提供的驱动解决了这个问题,我的打印机型号是M1005,推荐驱动foo2xqx,按照如下步骤安装(也可直接登陆http://foo2xqx.rkkda.com/按照提示安装):

$ wget -O foo2zjs.tar.gz http://foo2zjs.rkkda.com/foo2zjs.tar.gz
$ tar zxf foo2zjs.tar.gz
$ cd foo2zjs
$ make
$ make install
$ make install-hotplug
$ make cups
$ system-config-printer

最后一步设置时注意如果事先安装了hplip驱动那里会出现两个驱动,选择foo2xqx那个才行。

搞定收工,这次可以正常打印了。

CentOS iptables基本应用

一般系统都会自带iptables,如果没有自带,请用yum install直接安装。

1、开放指定端口

#允许本地回环接口(即运行本机访问本机)
iptables -A INPUT -s 127.0.0.1 -d 127.0.0.1 -j ACCEPT
# 允许已建立的或相关连的通行
iptables -A INPUT -m state --state ESTABLISHED,RELATED -j ACCEPT
#允许所有本机向外的访问
iptables -A OUTPUT -j ACCEPT
# 允许访问22端口
iptables -A INPUT -p tcp --dport 22 -j ACCEPT
#允许访问80端口
iptables -A INPUT -p tcp --dport 80 -j ACCEPT
#允许FTP服务的21和20端口
iptables -A INPUT -p tcp --dport 21 -j ACCEPT
iptables -A INPUT -p tcp --dport 20 -j ACCEPT
#如果有其他端口的话,规则也类似,稍微修改上述语句就行
#禁止其他未允许的规则访问
iptables -A INPUT -j REJECT  (注意:如果22端口未加入允许规则,SSH链接会直接断开。)
iptables -A FORWARD -j REJECT

2、屏蔽指定IP(可选)

如果有些已知IP是经常爆你的服务器的话,可以用规则将其屏蔽。

#如果只是想屏蔽IP的话“3、开放指定的端口”可以直接跳过。
#屏蔽单个IP的命令是
iptables -I INPUT -s 123.45.6.7 -j DROP
#封整个段即从123.0.0.1到123.255.255.254的命令
iptables -I INPUT -s 123.0.0.0/8 -j DROP
#封IP段即从123.45.0.1到123.45.255.254的命令
iptables -I INPUT -s 124.45.0.0/16 -j DROP
#封IP段即从123.45.6.1到123.45.6.254的命令是
iptables -I INPUT -s 123.45.6.0/24 -j DROP

3、保存规则&开机启动

service iptables save
chkconfig --level 345 iptables on

4、后续:查看与删除已经添加的规则

iptables -L -n

将所有iptables以序号标记显示,执行:

iptables -L -n --line-numbers

比如要删除INPUT里序号为8的规则,执行:

iptables -D INPUT 8

清除已有所有的iptables规则

iptables -F
iptables -X
iptables -Z