2010年6月9日星期三

Python学习笔记20100128

methodList = [method for method in dir(object) if callable(getattr(object, method))]
###插一句, ifconfig pcn0 unplumb 去禁solaris的网卡plumb起网卡
 
and, or  已经and-or一起用。
and 两者为真,print第二个数,一个为假一个为真返回假,三者为真返回最后一个真。
or 两个为真,返回第一个, 一个为假一个为真返回真,三者为假返回最后一个假
 
lambda可快速定义最小值函数
 
g = lambda x:x*2
g(3)
6
(lambda x:x*2)(3)
 
doc string
print getattr(object,mothod).__doc__
 
ljust
ljust 用空格填充字符串以符合指定的长度。info 函数使用它生成了两列输出并将所有在第二列的 doc string 纵向对齐。 如果小于的话不会从中截断
 
-----面向对象
首先导入,你可以选择import module or from module import module
如果你要经常访问模块的属性和方法,且不想一遍又一遍地敲入模块名,使用 from module import。
如果你想要有选择地导入某些属性和方法,而不想要其它的,使用 from module import。
如果模块包含的属性和方法与你的某个模块同名,你必须使用 import module 来避免名字冲突
 
-----类的定义
class Lofs
   pass
  这个类的名字是 Loaf,它没有从其它类继承。 类名通常是第一个字母大写,如:EachWordLikeThis,但这只是一个习惯,不是一个必要条件。
  这个类没有定义任何方法或属性,但是从语法上,需要在定义中有些东西,所以你使用 pass。这是一个 Python 保留字,仅仅表示 “向前走,不要往这看”。它是一条什么都不做的语句,当你删空函数或类时,它是一个很好的占位符。
  你可能猜到了,在类中的所有东西都要缩近,就象位于函数、if 语句,for 循环,诸如此类的代码。第一条不缩近的东西不属于这个类。
-----
class FileInfo(UserDict):
    "store file metadata"
    def __init__(self, filename=None):
        UserDict.__init__(self)       
        self["name"] = filename 
 
了解何时去使用 self 和 __init__
当定义你自已的类方法时,你必须明确将 self 作为每个方法的第一个参数列出,包括 __init__。当从你的类中调用一个父类的一个方法时,你必须包括 self 参数。但当你从类的外部调用你的类方法时,你不必对 self 参数指定任何值;你完全将其忽略,而 Python 会自动地替你增加实例的引用。
 
 
 
--
Alex Tu
-----------------------------------------------------------
ShangHai,China

pgsql

mysql                      psql

SHOW DATABASES;           \l
USE db-name;              \c db-name
SHOW TABLES;              \d
SHOW USERS;               \du
SHOW COLUMNS;             \d table-name
SHOW PROCESSLIST;         SELECT * FROM pg_stat_activity;
SELECT now()\G            \x 可以打开和关闭类似\G功能
SOURCE /path.sql          \i /path.sql
LOAD DATA INFILE ...      \copy ...
\h                        \?


--
Alex Tu
-----------------------------------------------------------
ShangHai,China

虚拟技术使用

Vmware ESXI 开始实用command line ,其实还是有其他登录方式的只不过用client管理比较好看而已。
Host装完以后, 可以alt-f1 然后输入unsupported再打回车符。 就可以进到里面 文章可以参考。 开启本机ssh和改变host.
vi /etc/inet.conf uncomment ssh. 然后在/etc/init一下, 不会影响已经启动的虚拟机。 然后直接可以从外网链接到command模式下.
 
由于自己已经能顺利实现在solaris上,讲zone占到nfs上。 具体步骤如下:

 

  1. make sure NFS is having enough space to install.
  2. make sure you have root permission.
  3. cd Path
  4. mkfile 6G zone ( the solaris standard installation will cost 6G and the filename is better the same as zone name)
  5. lofiadm ( run this command for confirming the link between path and the virtual devices)
  6. lofiadm –a /Path/zone /dev/lofi/* ( please count the * one by one)
  7. newfs /dev/lofi/*
  8. mkdir /localpath/zone (localpath as the old local zone path, zone name as NFS’ zone)
  9. mount /dev/lofi/* /localpath/zone
  10. chmod 700 /localpath/zone
  11. vi /zone.cfg (please modify the ip address, zonepath as required , do not modify the others)
  12. zonecfg –z zone –f /zone.cfg
  13. zoneadm list –ivc (confirm the zone had been listed, correct)
  14. zoneadm –z zone install
  15. zoneadm –z zone boot
  16. zlogin –C zone (set the normal way, use root000 as root password)
  17. vi /etc/sshd_config (commont root login)
  18. svcadm restart sshd
现在想试着将用vmware exsi使用nfs模式,将虚拟机装到nfs上,用windows的client端很容易实现挂在,无论是用nis share出来的盘,或者用netapp share出来的盘, 这样可以便于备份和便于换空间。  注意在写的使用用netapp的要写好/vol 之前因为没写,导致mount会有问题。
加载以后,数据饼图显示的话那块。
 
 
ESXI 相对于ESX 被阉割了很多功能,但是对于一般小型企业而言,已经够用。lun的storage需求基本没有。
在command命令下加在nas/NFS的share空间,esxcfg-nase -a /name -o hostname -s /vol 即可


upgrade 3.5 to 4.0 u1 use ESXi-4.0.0-1.9.208167-upgrade-release.zip
upgrede 4.0 to 4.0 u1 use ESXi-4.0.0-update01.zip
--
Alex Tu
-----------------------------------------------------------
ShangHai,China

2010年2月3日星期三

vmware esxi 安装

需求来自于save cost. 开始有用户需求部署vmware esxi为架构的虚拟机, 由于目前没有server来测试,用户自己找的pavilion的家用机系列也跑不了。只得从onsite那里借来一台xw4400.
这机器吧,挺好,xw4400开跑的64位虚拟支持的话,先得在Blos上设置下, 因为没有这方面经验,以为机器都能直接判断,但是从安装实录上里讲,需要在blos里这是,对于xw4400的设置是,security-os security- enable virtualization. 然后重启。顺便丢入光盘。
 
iso其实很小大概只有200多M,是一个linux kernel的东西。里面从个人观点来看,带有web接口。和管理接口。
安装程序会自动检测你机器的配置是否符合安装要求,家用额pavilion就没检测过,看网上资料,初步认定是网卡没有不办法兼容。 一路按照提示点F2和enter就成。由于是基于网络的,请注意ip的分配。
安装完成之后请拿出光盘,因为我之前就是这样犯了个错误,导致重复安装一次:(
 
重启之后,会有一个界面告诉你这个管理的http://ip是啥, 然后你可以通过windows client段去下载客户端管理工具,ci.
里面按f2是管理配置界面,可以配置root密码,ip地址等等,详细可以参考文章.
 
点击后的下载ci客户端,点击,输入控制端ip/用户名/密码。
然后就是如vmware的配置一般。
有一点奇怪的是,他竟然没有办法认出host上的光驱。好在有网络以后,他可以mount本机和网络上的盘,当然我指的是client上的物理光驱以及网络上的虚拟iso.
选择client的话,然后用物理光驱要选emulate cd.
安装非常的方便。
然后装完两个32bit and 64bit的suse.
用户开始test

--
Alex Tu
-----------------------------------------------------------
ShangHai,China

2010年1月27日星期三

Python学习笔记20100117

映射list
 
Dictionary 是用{}. list 是一那个[]. turple是用()
当你定义过dictionary后,你可以使用d.keys(), d.values(),d.items()将定义后的时候分别显示出来
当然可以将list里的值加减乘除,也可以如一般的定义直接重新复制这个list.
链接与分割字符串的
li=";", join(li) 则显示的就是 分隔符为;的数 如果使用li=li.split(";")则将刚刚;的分隔符删除,而split里也可定义域,如li.split(";",1)
 
自省 <---这是啥
之前在使用的时候发觉有些书本上的模块不能调用,很多是py脚本定义过的函数。
下载该脚本s,然后上传至指定位置。
>>>import sys
>>>sys.path
>>>sys.path.append("绝对位置")然后就能调用这些脚本和参数了。
删除
>>>sys.path.pop()
定义一个参数是 def info(test, test1=10.test2=12):
info是函数名,test是必备参数,因为没有定义值,test1和test2是可选参数,定义了初始值
 
以上是外部函数的调用,下面转到内部函数
内部函数有type,str,dir及其他
 
---type
返回任意字符的类型,模块也可以。types模块
>>> type(1)
<type 'int'>
>>> li=[]
>>> type(li)
<type 'list'>
>>> import odbchelper
>>> type(odbchelper)
<type 'module'>
>>> type(sys)
<type 'module'>
>>> import types
>>> type(odbchelper) == types.ModuleType
True
 
 
---str
str将强制转换字符串
>>> str(horsemen)
"['war', 'pestilence', 'famine', 'testing']" <---这个是一个字符串""
>>> str(odbchelper)
"<module 'odbchelper' from '/home/xtuulei/py/odbchelper.py'>"
str 还允许作用于模块。注意模块的字符串形式表示包含了模块在磁盘上的路径名,所以你的显示结果将会有所不同。
>>> str(None) ---书上说这个很重要,对空值的使用
'None'
 
---dir
相比较而言,不是很熟这个,但是貌似可以列出来所有li,d,funcation所包含的key
--callable
 
type、str、dir 和其它的 Python 内置函数都归组到了 __builtin__
你可以在其中使用
>>>form apihelper import info
>>>import __builtin__
>>>info(__buitin__)
 
---getattr
>>getattr(li,"pop")
该语句也是返回 pop 方法的引用,但是此时,方法名称是作为一个字符串参数传递给 getattr 函数的。getattr 是一个有用到令人无法致信的内置函数,可以返回任何对象的任何属性。
>>>getattr(li,"append")("Moe")
>>>li
getattr 的返回值 是 方法,然后你就可以调用它就像直接使用 li.append("Moe") 一样。但是实际上你没有直接调用函数;只是以字符串形式指定了函数名称。
getattr 也可以作用于字典
getattr 不仅仅适用于内置数据类型,也可作用于模块
 
getattr也可以做为一个分发者
getattr作为一个分发者的实例
statsout是附带的脚本,里面已经定义了output_html,output_xml,output_text
 
import statsout
def output(data, format="text"):
    output_function = getattr(statsout, "output_%s" % format, statsout.output_text)
    return output_function(data)
output_function第三个参数是被定义为缺省参数,在调用 getattr 时添加了第三个参数。第三个参数是一个缺省返回值,如果第二个参数指定的属性或者方法没能找到,则将返回这个缺省返回值
 

--
Alex Tu
-----------------------------------------------------------
ShangHai,China

2010年1月26日星期二

Python学习笔记2010026

开始学习python.
RH5已经开始内置python,而solaris还是没有嵌入但是机器上有,所以开始使用。
学习的教程是dive into python.网上有CHM和PDF, 个人现在看,由于篇幅大,但是相对来说基础知识涵盖的比较丰富。
安装就不提了,主要是在unix/linux上,所以直接跑。
xtuulei@cnshx021:%:python
Python 2.4.4 (#3, Dec  3 2007, 12:14:12)
[GCC 3.3.2] on sunos5
Type "help", "copyright", "credits" or "license" for more information.
 
根据教程,
def 定义函数,和抒写规则一样,建议按照标准的书写规则,空行已经。 """ """" 类似于dic string表示好注释一样。
if else一样都需要规范书写。
模块中定义import sys的时候, 键入sys.__name__可以表现出当前模块。
 
----------------dictionary定义
dictionary: 定义参数一一对应
d = {"test":"test1",42:"test2","test3":33,44:56} 无先后顺序。
定义修覆盖,可添加
d["test4"] = 22
d["Test"]= 22
 
del ["test4"] 可删除。
d.clear() 清空d
 
键入d显示结果。
键入d["test"]显示test值,但是键入d["test1"]不能显示test这个key
 
 
----------------- list定义
类似于数组
li = ["a","b","mpilgrim","z","example"]
键入li查看结果
从0开始计数
li[0] 结果等于a
但是同时可以反计数,从-1开始
li[-5] 结果等于a
 
>>> li[1:3] 
['b', 'mpilgrim']
您可以通过指定 2 个索引得到 list 的子集, 叫做一个 “slice” 。返回值是一个新的 list, 它包含了 list 中按顺序从第一个 slice 索引 (这里为 li[1]) 开始, 直到但是不包括第二个 slice 索引 (这里为 li[3]) 的所有元素。
>>> li[1:-1]
['b', 'mpilgrim', 'z']
如果一个或两个 slice 索引是负数, slice 也可以工作。如果对您有帮助, 您可以这样理解:从左向右阅读 list, 第一个 slice 索引指定了您想要的第一个元素, 第二个 slice 索引指定了第一个您不想要的元素。返回的值为在其间的每个元素
>>> li[0:3] 
['a', 'b', 'mpilgrim'
 List 从 0 开始, 所以 li[0:3] 返回 list 的前 3 个元素, 从 li[0] 开始, 直到但不包括 li[3]
 
li可以简写,可以将0去除,默认为0
li同样和dictionary一样可以增加参数
li.append("test") 在最后插入, 先前有个练习,在import sys后,键入sys.path可以看到sys module的具体路径,当打sys.append("path")就是意味在最后插入一段新的库包含的位置。
li.insert(2, "new") 如此可以指定li[2]是new,而如果用append加入的那个test换成new,两个不冲突。
li.extend(["test1","test2"])可以增加多个参数
 
extend和append的参数,extend将多个插入对象当作各个分布体,append讲多个插入对象当作一个整体.
PS. len(li)可读li的个数
 
在li[]中查找数目
li.index("test") index用于查询第一个出现的,而且也只显示第一个出现的index
要测试一个值是否在 list 内, 使用 in, 如果值存在, 它返回 True, 否则返为 False
"test" in li
True
 
删除li中的数值
li.remove 表示删除首次并只删除一个
li.pop() 表示删除最后一个,并返回该值
list做运算。
>>> li = ['a', 'b', 'mpilgrim']
>>> li = li + ['example', 'new']
>>> li
['a', 'b', 'mpilgrim', 'example', 'new']
Lists 也可以用 + 运算符连接起来。 list = list + otherlist 相当于 list.extend(otherlist)。 但 + 运算符把一个新 (连接后) 的 list 作为值返回, 而 extend 只修改存在的 list。 也就是说, 对于大型 list 来说, extend 的执行速度要快一些。
>>> li += ['two']         
>>> li
['a', 'b', 'mpilgrim', 'example', 'new', 'two']
Python 支持 += 运算符。 li += ['two'] 等同于 li.extend(['two'])
>>> li = [1, 2] * 3  
>>> li
[1, 2, 1, 2, 1, 2]
* 运算符可以作为一个重复器作用于 list。 li = [1, 2] * 3 等同于 li = [1, 2] + [1, 2] + [1, 2], 即将三个 list 连接成一个
 
------tuple
tuple创建和list一样,但是不能修改。 类似于list已经被写保护了。
 
-------变量
 
如上,变量可以被定义。
 
>> x =1
>>x
1
 
一个变量赋多值
>>> v = ('a', 'b', 'e')
>>>('x','y','z') = v
>>>a
      x

 

-------格式化字符串
>>> k = "uid"
>>> v = "sa"
>>> "%s=%s" % (k, v)
'uid=sa'
 
>>> uid = "sa"
>>> pwd = "secret"
>>> print pwd + " is not a good password for " + uid 
secret is not a good password for sa
+ 是字符串连接操作符。
>>> print "%s is not a good password for %s" % (pwd, uid)
secret is not a good password for sa
+和%s是一样的
>>> userCount = 6
>>> print "Users connected: %d" % (userCount, )  
Users connected: 6
字符串格式化通过将 %s 替换成 %d 即可处理整数 后面之所以写成这样就让他定义成一个tuple,让这个东西不可修改。
但其实如果
>>> userCount = 6
>>> print "Users connected: %d" % userCount
Users connected: 6

也是可以实现的


>>> print "Users connected: " + userCount
错误
 
>>> print "aha %f" % 13
>>> print "aha %2f" % 13
>>> print "aha %+.2f" % 1.5
>>> pring "aha %+2f" % 1.5
%f 格式符选项被认为是一个十进制浮点数, 不指定精度时打印 6 位小数。使用包含 ".2" 精度修正符的 %f 格式符选项将只打印 2 位小数。您甚至可以混合使用各种修正符。 添加 + 修正符用于在数值之前显示一个正号或负号。 注意 ".2" 精度修正符仍旧在他原来的位置, 用于只打印 2 位小数。


--
Alex Tu
-----------------------------------------------------------
ShangHai,China

2010年1月12日星期二

zone start on NFS and start issue.

前几日,用户有需求,因为本地硬盘是在是不够大了, 开始想将数据或者应该将zone的数据放在NFS上。 这就给出了个不小的难题,只能网上搜这样用法,从网上的说法来看,其实SUN官方还没有支持那么做。
当你在做zone直接放到nfs上时,他会报粗错。具体的错误为, zone detected it's not a local file system. balabala...
当时想取巧,在本机磁盘上建立个soft link让他能认为这个是本地硬盘,但事实证明是不成功的。
于是乎,在这千钧一发之际,万能的google又救命了。 详细请参阅 joost pronk's weblog .
根据实际情况进行总结。
 #mkdir 6G /nfs/test #之前建立过300M,但是由于目前Solaris 10的需求有将近6G左右
 #lofiadm -a /nfs/test /dev/lofi/1
#newfs /dev/lofi/1
#mkdir /zone/test_zone #建立本地磁盘目录
#mount /dev/lofi/1 /zone//test_zone
#chmod 700 /zone/test_zone
 
然后就可以按照一般的步骤那么安装下去。而且基本没什么岔子。
 
原本以后就这么了解了,结果没想周一来的时候zone在nfs上的起不了了。
看机器的状态zoneadm list -ivc是好的就是死活进不去, 然后只能就zoneadm -z testzone halt。 这时候发觉mount点mount不上去了。
mount的时候报i/o error而在机器log里面也
Jan 11 09:28:01 cnnjx026 devfsadmd[636]: [ID 272826 daemon.error] mknod failed for /local/zones/cnnjx026z019/dev/pts/356: I/O error
 
本来试着想用
#mount -o rw /dev/lofi/1 /zone/test_zone 还是错误后来试着read-only
#mount -o ro /dev/lofi/1 /zone/test_zone 是成功的。 那就怪了, 然后去nfs上查,发觉nfs的空间周末的时候蛮了,导致不能写入,然后mount但就掉了。清空部分空间以后,在mount还是不行,只得做一次
#fsck /dev/lofi/1 估计机器掉的时候还是在写数据,导致这个镜像在时候的时候也有问题。做完后
#mount /dev/lofi/1 /zone/test_zone 成功
#zoneadm -z test_zone boot
稍等后能就能进入。
 
想比较而言,在本地磁盘的zone管理更为方便,而nfs上的zone虽然为成本大大节省,但是不可预料性太大。 特别是一个相对复杂的r&d环境更是。
 

2010年1月8日星期五

Suse 开机不能进入os

接到个case。机器通电后死活进不了系统,onsite也不知道怎么进去看。 service desk只能派case到我这里。因为不能用正确的root password直接登录,所以只能另想办法。其实网上说要进入failsafe在打init=/bin/bash, 其实从个人使用后,发觉如果有failsafe以后硬盘是无法加载的,也许是因为这个机器之前的原因。 从总体上来看, 是因为硬盘出错导致没有办法做fsck。
系统提示只能手动做fsck.
按照init=/bin/bash后,进入会(none)#, 然后因为硬盘还没加载,但你可以使用大部分命令,可以run fsck.ext3然后就开始检测,这时候狂按y就成。系统检查完了,想reset root password但是这时候不能进入会提示module is unkwon...然后正常启动的时候,登录界面也没有办法得到焦点,切到ctrl+alt+f1也没办法登入。
那个郁闷啊, 这个时候只能停下来,看google。大部分的原因是因为pam不能正常工作导致的, 这点也是比较失败的地方,其实可以直接从/var/log/messages里面看到。 
后来查看了一下,确实pam出问题了,但是这个问题并不是源于机器本身的pam而是vas登录的时候在/opt/quest/lib/security/pam_vas.so这个文件丢失了, 那只能先把vas全部卸掉,然后重启,在rest root password. 这个时候就成功了, 然后只需要重新安装vas就好了 

--
Alex Tu
-----------------------------------------------------------
ShangHai,China