其实这个动作也很简单,只是python不像PHP那样默认支持mysql,所以我们必须为python安装一个mysql的扩展库。

1.首先下载
MySQL for python
因为我们是在windows下用的,所以我下载了一个MySQL-python-1.2.2.win32-py2.5.exe
2.直接执行安装,只要你已经安装过python,那么安装会相当顺利,一切默认即可完成安装了。
3.加载模块
如果我们执行import MySQLdb,没有报错,说明安装成功了,不过千万要注意大小写哦,很容易搞错的。
4.模块中的常用函数
connect()方法用于连接数据库,返回一个数据库连接对象。如果要连接一个位于host.remote.com服务器上名为fourm的MySQL数据库,连接串可以这样写:

db = MySQLdb.connect(host="remote.com",user="user",passwd="xxx",db="fourm" )connect()的参数列表如下:

host,连接的数据库服务器主机名,默认为本地主机(localhost)。

user,连接数据库的用户名,默认为当前用户。

passwd,连接密码,没有默认值。

db,连接的数据库名,没有默认值。

conv,将文字映射到Python类型的字典。默认为MySQLdb.converters.conversions

cursorclass,cursor()使用的种类,默认值为MySQLdb.cursors.Cursor。

compress,启用协议压缩功能。

named_pipe,在windows中,与一个命名管道相连接。

init_command,一旦连接建立,就为数据库服务器指定一条语句来运行。

read_default_file,使用指定的MySQL配置文件。

read_default_group,读取的默认组。

unix_socket,在unix中,连接使用的套接字,默认使用TCP。

port,指定数据库服务器的连接端口,默认是3306。

连接对象的db.close()方法可关闭数据库连接,并释放相关资源。

连接对象的db.cursor([cursorClass])方法返回一个指针对象,用于访问和操作数据库中的数据。

连接对象的db.begin()方法用于开始一个事务,如果数据库的AUTOCOMMIT已经开启就关闭它,直到事务调用commit()和rollback()结束。

连接对象的db.commit()和db.rollback()方法分别表示事务提交和回退。

指针对象的cursor.close()方法关闭指针并释放相关资源。

指针对象的cursor.execute(query[,parameters])方法执行数据库查询。

指针对象的cursor.fetchall()可取出指针结果集中的所有行,返回的结果集一个元组(tuples)。

指针对象的cursor.fetchmany([size=cursor.arraysize])从查询结果集中取出多行,我们可利用可选的参数指定取出的行数。

指针对象的cursor.fetchone()从查询结果集中返回下一行。

指针对象的cursor.arraysize属性指定由cursor.fetchmany()方法返回行的数目,影响fetchall()的性能,默认值为1。

指针对象的cursor.rowcount属性指出上次查询或更新所发生行数。-1表示还没开始查询或没有查询到数据。
5.使用例子
#!/usr/bin/python
import MySQLdb
try:  
 connection = MySQLdb.connect(user="user",passwd="password",host="xxx",db="test")except:
 print "Could not connect to MySQL server."
 exit( 0 )
try:
  cursor = connection.cursor()
  cursor.execute( "SELECT note_id,note_detail FROM note where note_id = 1" )
  print "Rows selected:", cursor.rowcount
  for row in cursor.fetchall():
      print "note : ", row[0], row[1]
  cursor.close()
Tags: ,
我们在umount的时候,有时候会碰到device is busy 的情况,那么怎么办呢?办法很简单。
先使用fuser命令。
如果你的系统命令中没有fuser,可以先安装
cd /usr/ports/sysutils/fuser/
make install

安装结束之后,fuser这个命令被放到/usr/local/bin/中
所以我们使用
cd /usr/local/bin/
fuser -ck 你的挂载路径(参数作用是直接KIll使用该路径的进程)
umount 你的挂载路径

这样我们就把设备忙的mount取消了。本文由ArthurXF倾情奉献。
Tags: ,

DD命令使用大全

2008/10/02 11:47 ArthurXF
dd 是 Linux/UNIX 下的一个非常有用的命令,作用是用指定大小的块拷贝一个文件,并在拷贝的同时进行指定的转换。

1. 命令简介

dd 的主要选项:

指定数字的地方若以下列字符结尾乘以相应的数字:

b=512, c=1, k=1024, w=2, xm=number m

if=file

输入文件名,缺省为标准输入。

of=file

输出文件名,缺省为标准输出。

ibs=bytes

一次读入 bytes 个字节(即一个块大小为 bytes 个字节)。

obs=bytes

一次写 bytes 个字节(即一个块大小为 bytes 个字节)。

bs=bytes

同时设置读写块的大小为 bytes ,可代替 ibs 和 obs 。

cbs=bytes

一次转换 bytes 个字节,即转换缓冲区大小。

skip=blocks

从输入文件开头跳过 blocks 个块后再开始复制。

seek=blocks

从输出文件开头跳过 blocks 个块后再开始复制。(通常只有当输出文件是磁盘或磁带时才有效)。

count=blocks

仅拷贝 blocks 个块,块大小等于 ibs 指定的字节数。

conv=conversion[,conversion...]

用指定的参数转换文件。

转换参数:

ascii 转换 EBCDIC 为 ASCII。

ebcdic 转换 ASCII 为 EBCDIC。

ibm 转换 ASCII 为 alternate EBCDIC.

block 把每一行转换为长度为 cbs 的记录,不足部分用空格填充。

unblock 使每一行的长度都为 cbs ,不足部分用空格填充。

lcase 把大写字符转换为小写字符。

ucase 把小写字符转换为大写字符。

swab 交换输入的每对字节。

noerror 出错时不停止。

notrunc 不截短输出文件。

sync 把每个输入块填充到ibs个字节,不足部分用空(NUL)字符补齐。


2.实例分析

       2.1.数据备份与恢复

               2.1.1整盘数据备份与恢复

               备份:

[Copy to clipboard] [ - ]
CODE:
dd if=/dev/hdx of=/dev/hdy

将本地的/dev/hdx整盘备份到/dev/hdy

[Copy to clipboard] [ - ]
CODE:
dd if=/dev/hdx of=/path/to/image

将/dev/hdx全盘数据备份到指定路径的image文件

[Copy to clipboard] [ - ]
CODE:
dd if=/dev/hdx | gzip >/path/to/image.gz

备份/dev/hdx全盘数据,并利用gzip工具进行压缩,保存到指定路径
               恢复:

[Copy to clipboard] [ - ]
CODE:
dd if=/path/to/image of=/dev/hdx

将备份文件恢复到指定盘

[Copy to clipboard] [ - ]
CODE:
gzip -dc /path/to/image.gz | dd of=/dev/hdx

将压缩的备份文件恢复到指定盘

               2.1.2.利用netcat远程备份

[Copy to clipboard] [ - ]
CODE:
dd if=/dev/hda bs=16065b | netcat < targethost-IP > 1234

在源主机上执行此命令备份/dev/hda

[Copy to clipboard] [ - ]
CODE:
netcat -l -p 1234 | dd of=/dev/hdc bs=16065b

在目的主机上执行此命令来接收数据并写入/dev/hdc

[Copy to clipboard] [ - ]
CODE:
netcat -l -p 1234 | bzip2 > partition.img
               netcat -l -p 1234 | gzip > partition.img

以上两条指令是目的主机指令的变化分别采用bzip2  gzip对数据进行压缩,并将备份文件保存在当前目录。

               2.1.3.备份MBR

               备份:

[Copy to clipboard] [ - ]
CODE:
dd if=/dev/hdx of=/path/to/image count=1 bs=512

备份磁盘开始的512Byte大小的MBR信息到指定文件
               恢复:

[Copy to clipboard] [ - ]
CODE:
dd if=/path/to/image of=/dev/hdx

将备份的MBR信息写到磁盘开始部分

               2.1.4.备份软盘

[Copy to clipboard] [ - ]
CODE:
dd if=/dev/fd0 of=disk.img count=1 bs=1440k

将软驱数据备份到当前目录的disk.img文件

               2.1.5.拷贝内存资料到硬盘

[Copy to clipboard] [ - ]
CODE:
dd if=/dev/mem of=/root/mem.bin bs=1024

将内存里的数据拷贝到root目录下的mem.bin文件

               2.1.6.从光盘拷贝iso镜像

[Copy to clipboard] [ - ]
CODE:
dd if=/dev/cdrom of=/root/cd.iso

拷贝光盘数据到root文件夹下,并保存为cd.iso文件              

       2.2.增加Swap分区文件大小

[Copy to clipboard] [ - ]
CODE:
dd if=/dev/zero of=/swapfile bs=1024 count=262144

创建一个足够大的文件(此处为256M)

[Copy to clipboard] [ - ]
CODE:
mkswap /swapfile

把这个文件变成swap文件

[Copy to clipboard] [ - ]
CODE:
swapon /swapfile

启用这个swap文件

[Copy to clipboard] [ - ]
CODE:
/swapfile swap swap defaults 0 0

在每次开机的时候自动加载swap文件, 需要在 /etc/fstab 文件中增加一行

       2.3.销毁磁盘数据

[Copy to clipboard] [ - ]
CODE:
dd if=/dev/urandom of=/dev/hda1

利用随机的数据填充硬盘,在某些必要的场合可以用来销毁数据。执行此操作以后,/dev/hda1将无法挂载,创建和拷贝操作无法执行。

       2.4磁盘管理

               2.4.1.得到最恰当的block size

[Copy to clipboard] [ - ]
CODE:
dd if=/dev/zero bs=1024 count=1000000 of=/root/1Gb.file
               dd if=/dev/zero bs=2048 count=500000 of=/root/1Gb.file
               dd if=/dev/zero bs=4096 count=250000 of=/root/1Gb.file      
               dd if=/dev/zero bs=8192 count=125000 of=/root/1Gb.file

通过比较dd指令输出中所显示的命令执行时间,即可确定系统最佳的block size大小

               2.4.2测试硬盘读写速度

[Copy to clipboard] [ - ]
CODE:
dd if=/root/1Gb.file bs=64k | dd of=/dev/null
               dd if=/dev/zero of=/root/1Gb.file bs=1024 count=1000000

通过上两个命令输出的执行时间,可以计算出测试硬盘的读/写速度      

               2.4.3.修复硬盘

[Copy to clipboard] [ - ]
CODE:
dd if=/dev/sda of=/dev/sda

当硬盘较长时间(比如1,2年)放置不使用后,磁盘上会产生magnetic flux point。当磁头读到这些区域时会遇到困难,并可能导致I/O错误。当这种情况影响到硬盘的第一个扇区时,可能导致硬盘报废。上边的命令有可能使这些数据起死回生。且这个过程是安全,高效的。
Tags: ,
  python是一门非常好用的编程语言,架构清晰,代码少,功能强大,很多大型网站都在使用python,我因为要用python写《功夫之王》游戏的服务器端,开始学习python,感觉上手很快,我的项目使用了WDDX和FLASH通讯,所以就需要用pyxml模块了,上网下载发现这个模块尽让没有支持python2.5的,那么只好自己动手丰衣足食了。下面是我用MinGW编译pyxml的过程,借助这个过程,大家还可以自己动手编译很多不支持python2.5的模块。这里做个小广告,本人受聘于上海非凡进修学院授课CSS,PHP,FREEBSD等课程,有想学习的请跟我联系,是要收学费的哦。QQ:29011218.

引用
1.下载pyxml
http://sourceforge.net/project/showfiles.php?group_id=6473
如果我们安装的python是2.2,2.3,2.4,那么直接下载windows下专用的版本安装即可。本文主要介绍如何用源码编译出python2.5下用的pyxml。我们选择下载PyXML-0.8.4.tar.gz,下载后解压缩,我放在D:\PyXML-0.8.4
2.下载安装MinGW
http://sourceforge.net/project/showfiles.php?group_id=2435&package_id=240780&release_id=595197
因为我们是在windows下用的,就下载MinGW-5.1.4.exe,下载后安装,我安装在D:\MinGW,安装的时候一定要选择MinGW base tools,g++ compiler,MinGW Make,其他的可以不选,不过如果你们想装个全的,就全部选上也可以,下载需要一段时间的,安全却很快。呵呵。
3.设置系统环境变量
将D:\mingw\bin加进系统环境变量,如果是VISTA系统,建议使用下面的批处理文件。
建立一个path.bat文件,里面放入如下内容:
@echo off

echo MinGW Enviroment Command Console
echo ....
echo ....
@set MINGWROOT=D:\MinGW
@set MINGWBIN=%MINGWROOT%\bin
@set MINGWINCLUDE=%MINGWROOT%\include
@set MINGWLIB=%MINGWROOT%\lib
@set MINGWLIBEXEC=%MINGWROOT%\libexec\gcc\mingw32\3.4.5
@set MINGWBIN2=%MINGWROOT%\mingw32\bin
@set MINGWLIB2=%MINGWROOT%\mingw32\lib\ldscripts
@set MINGW=%MINGWROOT%;%MINGWBIN%;%MINGWINCLUDE%;%MINGWLIB%;%MINGWLIBEXEC%;%MINGWLIB2%;%MINGWLIB2%

rem to add more resource paths just use the set command like above and the and it to the set PATH like below

@set Path=%MINGW%;%Path%
保存在dos模式下执行,然后用path确认如上的路径是否加入环境变量中。
4.设置配置文件指定编译器
在你安装python的路径建立一个配置文件。例如下面我建立的,记得路径和文件名要一样啊。
D:\Python25\Lib\distutils\distutils.cfg
在这个文件里面放入如下内容:
[build]
compiler=mingw32
保存就好了。
5.编译
进入dos模式,进入PyXML目录,执行下面的命令
python setup.py install
结果报了N个如下错误。
build\temp.win32-2.5\Release\extensions\pyexpat.o:pyexpat.c:(.text+0x1b1): undef
ined reference to `_imp___Py_NoneStruct'
不要慌张,经过我查阅资料后,找到的解决方案
6.解决
原因是python的扩展需要专门的类库处理,我这里有一个处理好的类库给大家,大家直接下载覆盖。
D:\Python25\libs\python25.lib,最好把以前的python25.lib备份一下,以备不时只需。
点击下载我编译好的python25.lib文件
7.再编译
再执行第5步的命令
python setup.py install
这次编译直接通过。
8.验证
进入python命令行交互界面运行“import xml.dom.ext"命令,如果没提示模块出错则说明安装成功。

希望上面的方法能够对大家有些帮助。本文由ArthurXF倾情奉献!
Tags: ,
文介绍手工为FreeBSD添加新硬盘的一般性方法。假设我们的FreeBSD已经有了一块IDE硬盘,我们需要为它添加一块新的IDE硬盘,并把新添加的硬盘的所有空间作为一个分区加载到/disk1下面。

基础知识

FreeBSD分区描述符为从"a"到"h"的8个字母。根据惯例,分区"c"被保留用作描述整个磁盘,"a"用作标识根分区,"b"用作标识交换分区。对于新添加的硬盘,我们常常只建立一个分区,标识为"e"。

IDE硬盘标记为ad,而SCSI硬盘标记为da,从0开始计数,因此,我们新添加的IDE硬盘将作为ad1出现在系统中。


一般步骤

把新的IDE硬盘接入系统,并确认开机以后系统找到了新添加的硬盘。可以通过检查/var/run/dmesg.boot来确认系统是否找到新添加的硬盘。

准备

vms# dd if=/dev/zero of=/dev/rad1 bs=1k count=1

1+0 records in

1+0 records out

1024 bytes transferred in 0.000822 secs (1245640 bytes/sec)

vms#

初始化磁盘

vms# fdisk -BI ad1

******* Working on device /dev/ad1 *******

fdisk: invalid fdisk partition table found

vms#


建立FreeBSD分区


vms# disklabel -B -w -r ad1s1 auto

vms# Feb 23 14:01:40 /kernel: ad1: cannot find label (no disk label)

Feb 23 14:01:40 /kernel: ad1s1: cannot find label (no disk label)

Feb 23 14:01:40 /kernel: ad1: cannot find label (no disk label)

Feb 23 14:01:40 /kernel: ad1s1: cannot find label (no disk label)

vms#


建立逻辑分区


vms# disklabel -e ad1s1


type: unknown

disk: amnesiac

label:

flags:

bytes/sector: 512

sectors/track: 63

tracks/cylinder: 16

sectors/cylinder: 1008

cylinders: 18931

sectors/unit: 19083393

rpm: 3600

interleave: 1

trackskew: 0

cylinderskew: 0

headswitch: 0 # milliseconds

track-to-track seek: 0 # milliseconds

drivedata: 0


8 partitions:

# size offset fstype [fsize bsize bps/cpg]

c: 19083393 0 unused 0 0 # (Cyl. 0 - 18931*)

e: 19083393 0 4.2BSD 4096 8192 16 # (Cyl. 0 - 18931*)


格式化分区,创建文件系统


vms# newfs /dev/ad1s1e

Warning: Block size and bytes per inode restrict cylinders per group to 67.

Warning: 3968 sector(s) in last cylinder unallocated

/dev/ad1s1e: 19083392 sectors in 4660 cylinders of 1 tracks, 4096 sectors

9318.1MB in 70 cyl groups (67 c/g, 134.00MB/g, 8512 i/g)

super-block backups (for fsck -b #) at:

32, 274464, 548896, 823328, 1097760, 1372192, 1646624, 1921056, 2195488, 2469920, 2744352, 3018784, 3293216, 3567648,

3842080, 4116512, 4390944, 4665376, ...


加载分区

vms# mkdir -p /disk1

vms# mount -t ufs /dev/ad1s1e /disk1
分页: 55/128 第一页 上页 50 51 52 53 54 55 56 57 58 59 下页 最后页 [ 显示模式: 摘要 | 列表 ]