我的杂记



ubuntu server中文的问题“
sudo apt-get install language-pack-zh-han*


1.编辑/var/lib/locales/supported.d/local文件,内容改成如下:
en_US.UTF-8 UTF-8
zh_CN.UTF-8 UTF-8
zh_CN.GBK GBK
zh_CN GB2312
2. locale重新生成:
sudo locale-gen
3. 修改缺省的编码为zh_CN.UTF-8
vi /etc/default/locale


内容为:
LANG=”zh_CN.UTF-8″
LANGUAGE=”zh_CN:zh”
LC_NUMERIC=”zh_CN.UTF-8″
LC_TIME=”zh_CN.UTF-8″
LC_MONETARY=”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″
4. 退出,然后重新登陆进来应该就ok了。


lry@UbuntuServer:~$ locale
LANG=zh_CN.UTF-8
LANGUAGE=zh_CN:zh
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=


1、安装中文语言包
apt-get install language-pack-zh
2、用vim配置语言环境变量
vim /etc/environment
在下面添加如下两行
LANG=”zh_CN.UTF-8″
LANGUAGE=”zh_CN:zh:en_US:en”
如果你想用英文环境了,改成这两行就OK
LANG=”en_US.UTF-8″
LANGUAGE=”en_US:en”
3、重启Ubuntu Server
reboot
4、可以用locale查看一下环境变量...
locale


环境是ubuntu server 12.04, 中文显示乱码。配置locale环境,把过程记录下来。
1.查看当前的locale设置,输入
[plain] view plaincopyprint?
locale -a  
显示(不懂什么意思):
CPOSIC
2.用文本编辑器(我用的是vim),如果文件不存在则新建。


[plain] view plaincopyprint?
vim /var/lib/locales/supported.d/local  


在文件中加入下面2行:


[plain] view plaincopyprint?
en_US.UTF-8 UTF-8zh_CN.UTF-8   UTF-8  


3.用vim编辑 文件/etc/environment


[plain] view plaincopyprint?
vim /etc/environment  


在文件中加入:


[plain] view plaincopyprint?
LANG=”zh_CN.UTF-8”LANGUAGE=”zh_CN:zh:en_US:en”LC_CTYPE=”zh_CN.UTF-8”  




4.生成需要的locale文件,在终端中输入:
[plain] view plaincopyprint?
locale-gen #可以加 --purge参数用来删除所有旧的配置,在出现问题时很有用  




5.看看效果,编辑wordpress的配置文件,发个图,中文乱码消失了XD




For the 32-bit package:


sudo dpkg -i teamviewer_linux.deb
For the 64-bit package:


sudo dpkg -i teamviewer_linux_x64.deb
In case “dpkg” indicates missing dependencies, complete the installation by executing the following command:


sudo apt-get install -f
Notes to Multiarch:
On newer 64-bit DEB-systems with Multiarch-support (Debian 7) teamviewer_linux_x64.deb cannot be installed because the package ia32-libs is not available anymore on these systems. In this case you can use teamviewer_linux.deb instead.


In case you get the error “wrong architecture i386” you have to execute the following command lines:


dpkg --add-architecture i386
apt-get update
For further information: http://wiki.debian.org/Multiarch/HOWTO




安装sudo apt-get install lynx-cur
lynx -mime_header -auth=lqsn:lqrensn106 "http://members.3322.net/dyndns/update?system=dyndns&hostname=lqsn.3322.org"


teamview同类产品:
reDuh
softether
vpn-x http://www.birdssoft.com/zh-Hans/downloads/user-manual/
PacketiX




# LC_ALL=C TZ=UTC0 diff -Naur old new > foo.patch


如果不在意字符集,时差等问题,也可以省略LC_ALL=C TZ=UTC0环境变量:


# diff -Naur old new > foo.patch


保证当前目录是demo名录:


# mkdir demo
# cd demo


先模拟一个项目目录old:


# mkdir -p old/a/b
# vi old/a/b/foo.txt
old_line_1
old_line_2


假设我们发现项目old有bug代码,下面我们先拷贝一个新目录new,并在此修改bug代码:


# cp -r old new
# vi new/a/b/foo.txt
new_line_1
new_line_2


保证old和new两个目录都在当前目录下,下面就可以使用diff命令了,不要使用绝对路径,而应该使用相对路径,至于原因,看到文章结尾你就清楚了:


# LC_ALL=C TZ=UTC0 diff -Naur old new > foo.patch


如果不在意字符集,时差等问题,也可以省略LC_ALL=C TZ=UTC0环境变量:


# diff -Naur old new > foo.patch


其中-Naur参数属于固定打法,不管是对一个文件,还是对一个目录,在使用这个参数基本就可以了。


大概浏览一下补丁文件:


# cat foo.patch
diff -Naur old/a/b/foo.txt new/a/b/foo.txt
--- old/a/b/foo.txt     2009-12-07 20:40:07.000000000 +0800
+++ new/a/b/foo.txt     2009-12-07 20:41:51.000000000 +0800
@@ -1,2 +1,2 @@
-old_line_1
-old_line_2
+new_line_1
+new_line_2


加减号后面的内容是有用的内容,其他的内容是方便你查阅的相关信息内容,补丁制作完成。


此时的文件目录结构大概如下所示:


#tree
demo
|-- old
|   `-- a
|       `-- b
|           `-- foo.txt
|-- new
|   `-- a
|       `-- b
|           `-- foo.txt
`-- foo.patch


下面看看如何使用patch来应用补丁,要注意的是当前目录是demo,试试下面命令:


# patch -p0 < foo.patch
patching file old/a/b/foo.txt


这里唯一需要说明的是p0的含义,因为在foo.patch补丁文件里的路径信息是这样的:


--- old/a/b/foo.txt


p表示跳过几级目录,因为是在demo目录下使用的patch命令,old目录就在demo目录下,所以不必跳过任何目录,而应该使用old/a/b/foo.txt完整路径,所以此时使用的是p0。


查看一下目标文件,你会发现内容已经修改成新的了:


# cat old/a/b/foo.txt
new_line_1
new_line_2


此时如果你再次使用patch命令,系统会问你是否想还原:


# patch -p0 < foo.patch
patching file old/a/b/foo.txt
Reversed (or previously applied) patch detected!  Assume -R? [n] y


查看一下目标文件,你会发现内容已经还原成旧的了:


# cat old/a/b/foo.txt
old_line_1
old_line_2


如果你想严格指定是应用补丁可以使用下面命令(就是增加N参数):


# patch -Np0 < foo.patch


如果你想严格指定是还原补丁可以使用下面命令(就是增加R参数):


# patch -Rp0 < foo.patch


注释:在本例中,每次应用补丁后,自己还原补丁,以备后用继续试验,我就不多说了。


看到这里如果你对patch的p参数还不太清楚的话,接着往下看,我们改变一下当前路径:


# cd old


此时就应该是p1,而不是p0了,引用foo.patch文件的路径也要相对变一下,因为当前目录已经是old了:


# patch -p1 < ../foo.patch
patching file a/b/foo.txt


因为此时我们是在old下使用patch命令,和a子目录平级,而补丁文件foo.patch里的路径声明是:


--- old/a/b/foo.txt


也就是说第一个斜线左边的old/部分已经没用了,这就是p1的含义!


继续往深度变换路径,依次测试使用p2,p3参数:


# cd a


# patch -p2 < ../../foo.patch
patching file b/foo.txt


# cd b


# patch -p3 < ../../../foo.patch
patching file foo.txt 


在本例中,p3已经是最深目录了,此时可以省略p参数:


# patch < ../../../foo.patch
patching file foo.txt


也就是说,不使用p参数的时候,patch命令会忽略任何目录,直接使用文件。


下面接着文章前面说的为什么使用diff命令时最好不要使用绝对路径,而应该使用相对路径?


答:如果你在使用diff的时候使用的是绝对路径,那么补丁文件里的文件路径信息会类似下面的样子:


--- /a/b/c/d/e/f/g/bar.txt


如此一来,当别人想应用你的补丁时,因为目录结构肯定有差异,所以就不得不费力判断到底使用p几。这样一来就很容易出错,相反,如果使用相对路径的话,大多数时候,p0或者p1就足够了,不易出错。


跟着本文的步骤操作一下,肯定能掌握diff&patch用法,基本上使用diff时就是"diff -Naur FROM TO"(FROM, TO为变量)这样的固定打法,然后在使用patch的时候,先看看补丁文件的大致内容,结合当前目录以确定需要跳过的目录数,然后套用"patch -pN < patch.file"(N为变量)即可。




保证当前目录是demo名录:


# mkdir demo
# cd demo


先模拟一个项目目录old:


# mkdir -p old/a/b
# vi old/a/b/foo.txt
old_line_1
old_line_2


假设我们发现项目old有bug代码,下面我们先拷贝一个新目录new,并在此修改bug代码:


# cp -r old new
# vi new/a/b/foo.txt
new_line_1
new_line_2


保证old和new两个目录都在当前目录下,下面就可以使用diff命令了,不要使用绝对路径,而应该使用相对路径,至于原因,看到文章结尾你就清楚了:


# LC_ALL=C TZ=UTC0 diff -Naur old new > foo.patch


如果不在意字符集,时差等问题,也可以省略LC_ALL=C TZ=UTC0环境变量:


# diff -Naur old new > foo.patch


其中-Naur参数属于固定打法,不管是对一个文件,还是对一个目录,在使用这个参数基本就可以了。


大概浏览一下补丁文件:


# cat foo.patch
diff -Naur old/a/b/foo.txt new/a/b/foo.txt
--- old/a/b/foo.txt     2009-12-07 20:40:07.000000000 +0800
+++ new/a/b/foo.txt     2009-12-07 20:41:51.000000000 +0800
@@ -1,2 +1,2 @@
-old_line_1
-old_line_2
+new_line_1
+new_line_2


加减号后面的内容是有用的内容,其他的内容是方便你查阅的相关信息内容,补丁制作完成。


此时的文件目录结构大概如下所示:


#tree
demo
|-- old
|   `-- a
|       `-- b
|           `-- foo.txt
|-- new
|   `-- a
|       `-- b
|           `-- foo.txt
`-- foo.patch


下面看看如何使用patch来应用补丁,要注意的是当前目录是demo,试试下面命令:


# patch -p0 < foo.patch
patching file old/a/b/foo.txt


这里唯一需要说明的是p0的含义,因为在foo.patch补丁文件里的路径信息是这样的:


--- old/a/b/foo.txt


p表示跳过几级目录,因为是在demo目录下使用的patch命令,old目录就在demo目录下,所以不必跳过任何目录,而应该使用old/a/b/foo.txt完整路径,所以此时使用的是p0。


查看一下目标文件,你会发现内容已经修改成新的了:


# cat old/a/b/foo.txt
new_line_1
new_line_2


此时如果你再次使用patch命令,系统会问你是否想还原:


# patch -p0 < foo.patch
patching file old/a/b/foo.txt
Reversed (or previously applied) patch detected!  Assume -R? [n] y


查看一下目标文件,你会发现内容已经还原成旧的了:


# cat old/a/b/foo.txt
old_line_1
old_line_2


如果你想严格指定是应用补丁可以使用下面命令(就是增加N参数):


# patch -Np0 < foo.patch


如果你想严格指定是还原补丁可以使用下面命令(就是增加R参数):


# patch -Rp0 < foo.patch


注释:在本例中,每次应用补丁后,自己还原补丁,以备后用继续试验,我就不多说了。


看到这里如果你对patch的p参数还不太清楚的话,接着往下看,我们改变一下当前路径:


# cd old


此时就应该是p1,而不是p0了,引用foo.patch文件的路径也要相对变一下,因为当前目录已经是old了:


# patch -p1 < ../foo.patch
patching file a/b/foo.txt


因为此时我们是在old下使用patch命令,和a子目录平级,而补丁文件foo.patch里的路径声明是:


--- old/a/b/foo.txt


也就是说第一个斜线左边的old/部分已经没用了,这就是p1的含义!


继续往深度变换路径,依次测试使用p2,p3参数:


# cd a


# patch -p2 < ../../foo.patch
patching file b/foo.txt


# cd b


# patch -p3 < ../../../foo.patch
patching file foo.txt 


在本例中,p3已经是最深目录了,此时可以省略p参数:


# patch < ../../../foo.patch
patching file foo.txt


也就是说,不使用p参数的时候,patch命令会忽略任何目录,直接使用文件。


下面接着文章前面说的为什么使用diff命令时最好不要使用绝对路径,而应该使用相对路径?


答:如果你在使用diff的时候使用的是绝对路径,那么补丁文件里的文件路径信息会类似下面的样子:


--- /a/b/c/d/e/f/g/bar.txt


如此一来,当别人想应用你的补丁时,因为目录结构肯定有差异,所以就不得不费力判断到底使用p几。这样一来就很容易出错,相反,如果使用相对路径的话,大多数时候,p0或者p1就足够了,不易出错。


跟着本文的步骤操作一下,肯定能掌握diff&patch用法,基本上使用diff时就是"diff -Naur FROM TO"(FROM, TO为变量)这样的固定打法,然后在使用patch的时候,先看看补丁文件的大致内容,结合当前目录以确定需要跳过的目录数,然后套用"patch -pN < patch.file"(N为变量)即可。




制作补丁diff和打上补丁patch
(1)制作补丁:


假如linux-2.6.30是原始标准文件夹(也可以是文件,制作补丁diff时作为源文件夹),而linux-2.6.30_ok是你修改过用于发布的文件夹(制作补丁diff时作为目的文件夹)。这时只需制作一个补丁文件linux-2.6.30_ok.patch(它通常很小)来发布就行,而不用发布linux-2.6.30_ok。


#diff -urN linux-2.6.30 linux-2.6.30_ok > linux-2.6.30_ok.patch


(2)打补丁(升级)


只需有原始标准发布的文件解压后linux-2.6.30和补丁文件linux-2.6.30_ok.patch 就可以升级到linux-2.6.30_ok了(假设文件夹linux-2.6.30和linux-2.6.30.patch在同一目录下)


#patch -p1 < ../linux-2.6.30.patch


网上找来的总结:


单个文件
diff –uN  from-file  to-file  >to-file.patch
patch –p0 < to-file.patch
patch –RE –p0 < to-file.patch
多个文件
diff –uNr  from-docu  to-docu  >to-docu.patch
patch –p1 < to-docu.patch
patch –R –p1 <to-docu.patch
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值