# 7-公共API
# 异步线程池
# EmitOrder
描述
添加一个异步任务
参数
参数名 数据类型 说明 key string/int 相同key的任务,线程池顺序执行;不同key的任务,线程池会并行执行。可以确认某些任务按照顺序执行。 func function 任务对应的函数,该函数会在线程池中运行。该任务和主线程会并行执行,需要确认任务是线程安全的。函数必须返回一个元组,若返回为空则要求返回空元组("()")。函数输入参数是*args callback function 回调函数,它在主线程执行。func的返回值会是callback的实参。若没有回调,则传入None。 *args *args func函数的非关键字参数 返回值
无
示例
import time
import apolloCommon.workerPool as workerPool
def Callbacks(idx, result):
print "callbacks",idx, result
def Test(idx):
print "test start %d" % idx
time.sleep(1)
print "test fin %d" % idx
result = idx + 5
return (idx, result)#任务必须有返回值。若没有返回值,请返回 "()"
ins = workerPool.ForkNewPool(4)
for i in xrange(4):
#添加异步任务。i为奇数的任务顺序执行,i为偶数的任务顺序执行。这两批任务并行执行。
ins.EmitOrder(i%2, Test, Callbacks, i)
ins.Finish(None) #等待线程池退出。
# Finish
描述
等待线程池退出,线程池会执行完所有异步任务后退出,会阻塞主线程。建议Mod退出时执行
参数
参数名 数据类型 说明 timeout int 等待线程池退出时间,单位秒。若为None,则会一直等待。建议用None。 返回值
无
示例
import apolloCommon.workerPool as workerPool
ins = workerPool.ForkNewPool(4)
ins.Finish(None) #等待线程池退出。
# ForkNewPool
描述
创建线程池,设置线程池大小
参数
参数名 数据类型 说明 orderSize int 线程池的大小 返回值
数据类型 说明 MainPool 线程池实例 示例
import apolloCommon.workerPool as workerPool
ins = workerPool.ForkNewPool(10)
这里是mysql线程池的一些接口
# mysql连接池
# AsyncExecuteFunctionWithOrderKey
描述
添加一个异步mysql任务,func将在子线程中执行,注意func中不支持执行引擎提供的API
参数
参数名 数据类型 说明 func function mysql异步任务,可以没有返回值。该任务和主线程会并行执行,要求任务是线程安全的。第一个参数是一个mysql长连接,可以通过conn.cursor()获取cursor orderKey str/int 相同的orderKey会顺序执行,不同的orderKey会并行执行 callback function 回调函数,只有一个输入参数,它在主线程执行。func的返回值会是callback的实参。若func抛出异常,则callback输入参数是None。若没有回调,则传入None *args *args func的其它非关键字参数 **kwargs **kwargs 暂无用,预留用。 返回值
无
示例
def TestMysqlPoolCallback(records):
if records is None:
print "TestMysqlPoolCallback execute fail"
else:
print "TestMysqlPoolCallback execute success"
for line in records:
print "single record=%s" % str(line)
def mysqlFunc(conn, num):
cursor = conn.cursor()
query = "SELECT * FROM neteaseUserMail LIMIT %s"
params = (num, )
try:
cursor.execute(query, params)
records = cursor.fetchall()
except Exception as e:
logout.error("mysqlFunc error=%s"%str(e))
records = None
finally:
cursor.close()
return records
#执行事务的一个示例
def mysqlTransactionTest(conn):
conn.autocommit(False)
cursor = conn.cursor()
try:
params = (2, 'test_items')
query = "insert into neteaseCloudItems (uid, cloud_items) values (%s, %s)"
cursor.execute(query, params)
conn.commit()
except:
conn.rollback()
finally:
cursor.close()
conn.autocommit(True)#请务必将连接还原
import apolloCommon.mysqlPool as mysqlPool
mysqlPool.InitDB(5)
mysqlPool.AsyncExecuteFunctionWithOrderKey(mysqlFunc, "global", TestMysqlPoolCallback, 5)
mysqlPool.AsyncExecuteFunctionWithOrderKey(mysqlTransactionTest, "test_trans", None)
mysqlPool.Finish()
# AsyncExecuteWithOrderKey
描述
添加一个异步mysql任务,执行所有mysql操作
参数
参数名 数据类型 说明 orderKey str/int 相同的orderKey会顺序执行,不同的orderKey会并行执行 sql str mysql查询语句,格式化字符串 params tuple 填充sql callback function 回调函数,只有一个输入参数,它在主线程执行。func的返回值会是callback的实参。若func抛出异常,则callback输入参数是None。若没有回调,则传入None 返回值
无
示例
import apolloCommon.mysqlPool as mysqlPool
mysqlPool.InitDB(30)
def Cb(t):
#插入成功情况下,t的值:True
#插入失败情况下,t的值:False
print "cb", t
#添加异步任务。
mysqlPool.AsyncExecuteWithOrderKey('player', 'insert into player values (%s, %s)', (1, "test1"), Cb)
mysqlPool.Finish()
# AsyncExecutemanyWithOrderKey
描述
添加一个异步mysql任务,针对同一条sql语句,使用paramsList中的每个参数各执行一次,并且返回成功修改/新建的记录数,其中任何一条语句执行失败,最终所有语句都会被执行失败,返回None
参数
参数名 数据类型 说明 orderKey string/int 相同的orderKey会顺序执行,不同的orderKey会并行执行 sql string mysql插入语句,格式化字符串 callback function 回调函数,在主线程执行,只有唯一一个参数,成功修改/新建的记录数,假如sql执行失败,返回参数将会是None。若没有回调,则传入None 返回值
无
示例
import time
import apolloCommon.mysqlPool as mysqlPool
mysqlPool.InitDB(30)
def Cb(t):
#插入成功情况下,t的值:3
#插入失败情况下,可能出现部分数据插入成功问题,此时t的值:None
print "cb", t
#添加异步任务。
mysqlPool.AsyncExecutemanyWithOrderKey('pay', 'insert into pay values (%s, %s)', [(1,"648"),(2,"328"), (3,"345")], Cb)
for i in xrange(100):
mysqlPool.Tick()
time.sleep(0.2)
mysqlPool.Finish()
# AsyncInsertOneWithOrderKey
描述
添加一个异步mysql任务,向主键为AUTO INCREASEl类型的表格中插入一条记录,并且返回新建记录的主键
参数
参数名 数据类型 说明 orderKey string/int 相同的orderKey会顺序执行,不同的orderKey会并行执行 sql string mysql插入语句,格式化字符串 params tuple 填充sql callback function 回调函数,在主线程执行,只有唯一一个参数,是新建记录的主键,假如sql执行失败,返回参数将会是None。若没有回调,则传入None 返回值
无
示例
# 表testTable的创建语句如下
# CREATE TABLE IF NOT EXISTS `testTable` (
# `id` bigint unsigned NOT NULL AUTO_INCREMENT,
# `col_1` varchar(50) NOT NULL,
# PRIMARY KEY (`uid`)
# ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;
import apolloCommon.mysqlPool as mysqlPool
mysqlPool.InitDB(30)
def Cb(t):
#插入成功情况下,t的一个示例值(也即表testTable中列id对应值):1
#插入失败情况下,t的值:None
print "cb", t
#添加异步任务。
mysqlPool.AsyncInsertOneWithOrderKey('pay', 'insert into testTable (col_1) values (%s)', ("648"), Cb)
mysqlPool.Finish()
# AsyncQueryWithOrderKey
描述
添加一个异步mysql任务,执行mysql查询
参数
参数名 数据类型 说明 orderKey str/int 相同的orderKey会顺序执行,不同的orderKey会并行执行 sql str mysql查询语句,格式化字符串 params tuple 填充sql callback function 回调函数,只有一个输入参数,它在主线程执行。func的返回值会是callback的实参。若func抛出异常,则callback输入参数是None。若没有回调,则传入None 返回值
无
示例
import apolloCommon.mysqlPool as mysqlPool
mysqlPool.InitDB(30)
def Cb(t):
#查询到一条记录情况下,t的一个示例值:((1L, u'test_name_1', 0L),)
#查询为空情况下,t的值:()
#查询报错情况,t的值:None
print "cb", t
#添加异步任务。
mysqlPool.AsyncQueryWithOrderKey('player', 'select uid,name from player where uid = %s', (1,), Cb)
#等价于
#mysqlPool.AsyncQuery('player', 'select uid,name from player where uid = %s', (1,), Cb)
#orderKey都是'player',两个任务顺序执行。
mysqlPool.AsyncQueryWithOrderKey('player', 'select uid,name from player where uid = %s', (1,), Cb)
mysqlPool.Finish()
# Finish
描述
等待mysql线程池退出,会等待线程池中所有异步任务执行完毕后退出
返回值
无
示例
import apolloCommon.mysqlPool as mysqlPool
mysqlPool.Finish()
# InitDB
描述
初始化myqsl连接池,要求在MCStudio的“服务器配置”中配置mysql
参数
参数名 数据类型 说明 poolSize int 连接池大小 返回值
无
示例
import apolloCommon.mysqlPool as mysqlPool
mysqlPool.InitDB(30)
# SyncFetchAll
描述
阻塞性执行sql语句,查询数据
参数
参数名 数据类型 说明 sql string mysql查询语句,格式化字符串 params tuple 填充sql 返回值
数据类型 说明 None/list 错误返回None,否则返回列表,列表中每个元素表示一条查询记录 备注
建议只在初始化mod时执行这个api,不要在运行期间执行本api。它会阻塞主流程,可能导致服务器卡顿。
示例
import apolloCommon.mysqlPool as mysqlPool
sql = 'select _id, name from test_user where _id > %s'
#查询成功情况下,allRecords的一个示例值:((1L, u'test_name_1', 0L), (2L, u'test22', 2222L), (3L, u'test33', 333L))
#查询失败情况下,allRecords的值:None
allRecords = mysqlPool.SyncFetchAll(sql, (0, ))
for record in allRecords:
user['_id'] = record[0]#对应select后的第一个字段
user['name'] = record[1]#对应select后的第二个字段
# SyncInsert
描述
阻塞性执行sql语句,插入数据
参数
参数名 数据类型 说明 sql string mysql查询语句,格式化字符串 params tuple 填充sql 返回值
数据类型 说明 None/id 错误返回None,否则返回成功插入的id 备注
建议只在初始化mod时执行这个api,不要在运行期间执行本api。它会阻塞主流程,可能导致服务器卡顿。
示例
import apolloCommon.mysqlPool as mysqlPool
sql = 'insert into test_user(name, age) values(%s, %s)'
#插入成功情况下,返回值是插入的主键id
#插入失败情况下,返回值是0
insertId = mysqlPool.SyncInsert(sql, ("steve", 20))
这是redis线程池
# redis连接池
# AsyncDelete
描述
执行redis操作,删除某个redis key,相当于redis中执行命令:del key
参数
参数名 数据类型 说明 key string redis中的key callback function 回调函数,输入参数是redis操作返回值,是个int,表示删除redis key的个数 ,它在主线程执行。可以不传入回调函数。若redis操作抛出异常,则callback输入参数是None。若没有回调,则传入None 返回值
无
示例
import apolloCommon.redisPool as redisPool
def Cb1(t):
#执行成功且redis key "player_121"存在情况下,t的值:1
#执行成功且redis key "player_121"不存在情况下,t的值:0
#执行失败时,t的值:None
print "cb", t
redisPool.InitDB(30) #建立连接池
redisPool.AsyncDelete('player_121', cb1)
redisPool.Finish()
# AsyncFuncWithKey
描述
添加一个异步redis任务
参数
参数名 数据类型 说明 func function redis异步任务,可以没有返回值。该任务和主线程会并行执行,要求任务是线程安全的。第一个参数是一个redis长连接,是一个redis.StrictRedis实例,其他参数是*args orderKey str/int 相同的orderKey会顺序执行,不同的orderKey会并行执行 callback function 回调函数,只有一个输入参数,它在主线程执行。func的返回值是callback的输入参数。若func抛出异常,则callback输入参数是None。若没有回调,则传入None *args *args func的其它非关键字参数 **kwargs **kwargs 暂无用,预留用。 返回值
无
示例
import apolloCommon.redisPool as redisPool
redisPool.InitDB(30) #建立连接池
#回调,可以获取player的信息。这里只是打印结果。
def Cb1(t):
#执行成功且存在redis key "player_123"情况下,t的一个示例值:'test_string_value'
#执行成功且不存在redis key "player_123"情况下,t的值:""
#执行失败时,key的值:None
print "cb", t
#第一个参数是redis.StrictRedis实例。
def GetValueFromKey(conn, key):
ret = conn.get(key)
return ret if ret is not None else ""
#插入一个任务,从redis中获取uid为123玩家的信息。
redisPool.AsyncFuncWithKey(GetValueFromKey, "player_123", Cb1, 123)
#插入同样任务,orderKey都是“player_123”,因此两个任务会顺序执行。
redisPool.AsyncFuncWithKey(GetValueFromKey, "player_123", Cb1, 123)
redisPool.Finish()
# AsyncGet
描述
执行redis操作,获取key的value,相当于redis中执行命令:get key
参数
参数名 数据类型 说明 key str redis中的key callback function 回调函数,默认为空。函数输入参数是redis key对应的value字符串,它在主线程执行。若redis操作抛出异常,则callback输入参数是None。若没有回调,则传入None 返回值
无
示例
import apolloCommon.redisPool as redisPool
def Cb1(t):
#执行成功且存在redis key "player_123"情况下,t的一个示例值:'test_string_value'
#执行成功且不存在redis key "player_123"情况下,t的值:None
#执行失败时,key的值:None
print "cb", t
redisPool.InitDB(30) #建立连接池
redisPool.AsyncGet("player_123", Cb1)
redisPool.Finish()
# AsyncHgetall
描述
执行redis操作,获取key的value,相当于redis中执行命令:hgetall key
参数
参数名 数据类型 说明 key string redis中的key callback function 回调函数,输入参数是redis key对应的值,是个dict,它在主线程执行。可以不传入回调函数。若redis操作抛出异常,则callback输入参数是None。若没有回调,则传入None 返回值
无
示例
import apolloCommon.redisPool as redisPool
def Cb1(t):
#执行成功且redis key "player_123"不为空情况下,t的一个示例值:{'name': 'name', 'lv': '2'}
#执行成功且redis key "player_123"为空情况下,t的值:{}
#执行失败时,t的值:None
print "cb", t
redisPool.InitDB(30) #建立连接池
redisPool.AsyncHgetall("h_player_123", Cb1)
redisPool.Finish()
# AsyncMget
描述
执行redis操作,获取多个key的值,相当于redis中执行命令:mget key1 key2 ...
参数
参数名 数据类型 说明 key list/tuple 多个redis中的key callback function 回调函数,默认为空。函数输入参数redis操作返回值, 是个列表,每个元素对应单个redis key的值,它在主线程执行。若redis操作抛出异常,则callback输入参数是None。若没有回调,则传入None 返回值
无
示例
import apolloCommon.redisPool as redisPool
def Cb1(t):
#执行成功且redis key "test_value_None"不存在情况下,t的一个示例值:{'1': 'str', None}
#执行失败时,t的值:None
print "cb", t
redisPool.InitDB(30) #建立连接池
keys = ("test_value_1", "test_value_str", "test_value_None")
redisPool.AsyncMget(keys, Cb1)
redisPool.Finish()
# AsyncSet
描述
执行redis操作,设置key的值为value,相当于redis中执行命令:set key value
参数
参数名 数据类型 说明 key string redis中的key value string redis中key的值 callback function 回调函数,默认为空。函数输入参数是redis操作返回值,True表示设置成功,False失败。 若redis操作抛出异常,则callback输入参数是None。若没有回调,则传入None 返回值
无
示例
import apolloCommon.redisPool as redisPool
redisPool.InitDB(30) #建立连接池
def cb1(t):
#执行成功时,t的值:True
#执行失败时,t的值:False
print "cb", t
redisPool.AsyncSet('player_123', "{'name':'nickname'}", cb1)
redisPool.Finish()
# Finish
描述
等待redis线程池退出,会等待线程池中所有异步任务执行完毕后退出
返回值
无
示例
import apolloCommon.redisPool as redisPool
redisPool.InitDB(30) #建立连接池
#添加异步任务。在redis中执行:set "key1", "value11"
redisPool.AsyncSet("key1", "value11")
redisPool.Finish()
# InitDB
描述
初始化redis连接池,要求在MCStudio的“服务器配置”中配置redis
参数
参数名 数据类型 说明 poolSize int 连接池大小 返回值
无
示例
import apolloCommon.redisPool as redisPool
redisPool.InitDB(30)
这是mongo线程池
# mongo连接池
# AsyncExecute
描述
添加一个异步mongo任务
参数
参数名 数据类型 说明 collection str mongo中的一个集合,相同集合的所有操作串行执行,不同集合操作并行执行 func function mongo异步任务,可以没有返回值。该任务和主线程会并行执行,要求任务是线程安全的。第一个参数是一个mongo长连接,是pymongo.MongoClient连接池实例中的一个连接 callback function 回调函数,只有一个输入参数,它在主线程执行。func的返回值会是callback的实参。若func抛出异常,则callback输入参数是None。若没有回调,则传入None *args *args func的其它非关键字参数 **kwargs **kwargs 暂无用,预留用 返回值
无
示例
import apolloCommon.mongoPool as mongoPool
mongoPool.InitDB(32)
def Insert(col):
postData = {
'title': 'Python and MongoDB',
'content': 'PyMongo is fun, you guys',
'author': 'Scott'
}
col.insert_one(postData)
def Cb(t):
print "cb", t
#添加异步任务。
mongoPool.AsyncExecute("test_col", Insert, Cb)
mongoPool.Finish()
# AsyncExecuteWithOrderKey
描述
添加一个异步mongo任务。同async_execute区别是,可以显示设置orderKey
参数
参数名 数据类型 说明 collection str mongo中的一个集合 func function mongo异步任务,可以没有返回值。该任务和主线程会并行执行,要求任务是线程安全的。第一个参数是一个mongo长连接,是pymongo.MongoClient连接池实例中的一个连接 orderKey str/int 相同的orderKey会顺序执行,不同的orderKey会并行执行 callback function 回调函数,只有一个输入参数,它在主线程执行。func的返回值会是callback的实参。若func抛出异常,则callback输入参数是None。若没有回调,则传入None *args *args func的其它非关键字参数 **kwargs **kwargs 暂无用,预留用。 返回值
无
示例
import apolloCommon.mongoPool as mongoPool
mongoPool.InitDB(32)
def Insert(col):
postData = {
'title': 'Python and MongoDB',
'content': 'PyMongo is fun, you guys',
'author': 'Scott'
}
col.insert_one(postData)
def Cb(t):
print "cb", t
#添加异步任务。
#下面操作相当于:mongoPool.AsyncExecute("test_col", Insert, Cb)
mongoPool.AsyncExecuteWithOrderKey("test_col", Insert, "test_col", Cb)
#添加相同任务,两个任务顺序执行。
mongoPool.AsyncExecuteWithOrderKey("test_col", Insert, "test_col", Cb)
mongoPool.Finish()
# Finish
描述
等待mongo线程池退出,会等待线程池中所有异步任务执行完毕后退出
返回值
无
示例
import apolloCommon.mongoPool as mongoPool
mongoPool.InitDB(32)
mongoPool.Finish()
# InitDB
描述
初始化mongo连接池,要求在MCStudio的“服务器配置”中配置mongo
参数
参数名 数据类型 说明 poolSize int 连接池大小 返回值
无
示例
import apolloCommon.mongoPool as mongoPool
mongoPool.InitDB(32)
这里是mysql扩展线程池的一些接口
# mysql连接池扩展
# AsyncExecuteWithOrderKey
描述
添加一个异步mysql任务,执行所有mysql操作。同AsyncExecute的区别是可以显示指定orderKey
参数
参数名 数据类型 说明 dbName string mysql db名字,名字在deploy.json中extra_mysql下配置,具体参见InitDB备注说明 orderKey string/int 相同的orderKey会顺序执行,不同的orderKey会并行执行 sql string mysql查询语句,格式化字符串 params tuple 填充sql callback function 回调函数,只有一个输入参数,它在主线程执行。func的返回值会是callback的实参。若func抛出异常,则callback输入参数是None。若没有回调,则传入None 返回值
无
示例
import apolloCommon.extraMysqlPool as extraMysqlPool
extraMysqlPool.InitDB('mysql_test1', 30)
def Cb(t):
print "cb", t
#添加异步任务
extraMysqlPool.AsyncExecuteWithOrderKey('mysql_test1', 'player', 'insert into player values (%s, %s)', (1, "test1"), Cb)
extraMysqlPool.Finish()
# AsyncQueryWithOrderKey
描述
添加一个异步mysql任务,执行mysql查询。同AsyncQuery区别是可以显示指定orderKey
参数
参数名 数据类型 说明 dbName string mysql db名字,名字在deploy.json中extra_mysql下配置,具体参见InitDB备注说明 orderKey string/int 相同的orderKey会顺序执行,不同的orderKey会并行执行 sql string mysql查询语句,格式化字符串 params tuple 填充sql callback function 回调函数,只有一个输入参数,它在主线程执行。func的返回值会是callback的实参。若func抛出异常,则callback输入参数是None。若没有回调,则传入None 返回值
无
示例
import apolloCommon.extraMysqlPool as extraMysqlPool
extraMysqlPool.InitDB('mysql_test1', 30)
def Cb(t):
print "cb", t
#添加异步任务
extraMysqlPool.AsyncQueryWithOrderKey('mysql_test1', 'player', 'select uid,name from player where uid = %s', (1,), Cb)
#orderKey都是'player',两个任务顺序执行
extraMysqlPool.AsyncQueryWithOrderKey('mysql_test1','player', 'select uid,name from player where uid = %s', (1,), Cb)
extraMysqlPool.Finish()
# Finish
描述
等待mysql线程池退出,会等待线程池中所有异步任务执行完毕后退出
返回值
无
示例
import apolloCommon.extraMysqlPool as extraMysqlPool
extraMysqlPool.Finish()
# InitDB
描述
初始化mysql连接池。可以支持多个mysql实例,它可以同“mysql连接池”一起使用。MCStudio打开配置文件目录,在deploy.json文件中配置extra_mysql,配置方法参见备注
参数
参数名 数据类型 说明 dbName string mysql db名字,名字在deploy.json中extra_mysql下配置,比如示例配置中 “mysql_test1” poolSize int 连接池大小 返回值
无
备注
deploy.json中部分配置的示例如下:
"mysql": { "database": "mod_test", "host": "127.0.0.1", "password": "test", "port": 3306, "user": "test" }, "extra_mysql":{ "test1":{ "database": "mysql_test1", "host": "127.0.0.2", "password": "test", "port": 3306, "user": "test" }, "test2":{ "database": "mysql_test2", "host": "127.0.0.3", "password": "test", "port": 3306, "user": "test" } },
示例
import apolloCommon.extraMysqlPool as extraMysqlPool
extraMysqlPool.InitDB('mysql_test1', 30)
这里是redis扩展线程池的一些接口
# redis连接池扩展
# AsyncDelete
描述
执行redis操作,删除某个redis key,相当于redis中执行命令:del key
参数
参数名 数据类型 说明 dbName str redis db名字,名字对应MCStudio中新增redis实例的实例名称 key str redis中的key callback function 回调函数,默认为空。函数输入参数是redis操作返回值,是个int,表示删除redis key的个数 ,它在主线程执行。若redis操作抛出异常,则callback输入参数是None。若没有回调,则传入None 返回值
无
示例
import apolloCommon.extraRedisPool as extraRedisPool
def Cb1(t):
print "cb", t
extraRedisPool.InitDB('extra_redis1', 30) #建立连接池
extraRedisPool.AsyncDelete('extra_redis1', 'player_121', Cb1)
extraRedisPool.Finish()
# AsyncFuncWithKey
描述
添加一个异步redis任务
参数
参数名 数据类型 说明 dbName str redis db名字,名字对应MCStudio中新增redis实例的实例名称 func function redis异步任务,可以没有返回值。该任务和主线程会并行执行,要求任务是线程安全的。第一个参数是一个redis长连接,是一个redis.StrictRedis实例,其他参数是*args orderKey str/int 相同的orderKey会顺序执行,不同的orderKey会并行执行 callback function 回调函数,只有一个输入参数,它在主线程执行。func的返回值是callback的输入参数。若func抛出异常,则callback输入参数是None。若没有回调,则传入None *args *args func的其它非关键字参数 **kwargs **kwargs 暂无用,预留用 返回值
无
示例
import apolloCommon.extraRedisPool as extraRedisPool
extraRedisPool.InitDB('extra_redis1', 30) #建立连接池
#回调,可以获取player的信息。这里只是打印结果。
def Cb1(t):
print "cb", t
#第一个参数是redis.StrictRedis实例。
def GetValueFromKey(conn, key):
return conn.get(key)
#插入一个任务,从redis中获取uid为123玩家的信息。
extraRedisPool.AsyncFuncWithKey('extra_redis1', GetValueFromKey, 'player_123', Cb1, 123)
#插入同样任务,orderKey都是“player_123”,因此两个任务会顺序执行。
extraRedisPool.AsyncFuncWithKey('extra_redis1', GetValueFromKey, 'player_123', Cb1, 123)
extraRedisPool.Finish()
# AsyncGet
描述
执行redis操作,获取key的value,相当于redis中执行命令:get key
参数
参数名 数据类型 说明 dbName str redis db名字,名字对应MCStudio中新增redis实例的实例名称 key str redis中的key callback function 回调函数,默认为空。函数输入参数是redis key对应的value字符串,它在主线程执行。若redis操作抛出异常,则callback输入参数是None。若没有回调,则传入None 返回值
无
示例
import apolloCommon.extraRedisPool as extraRedisPool
def Cb1(t):
print "cb", t
extraRedisPool.InitDB('extra_redis1', 30) #建立连接池
extraRedisPool.AsyncGet('extra_redis1','player_123', Cb1)
extraRedisPool.Finish()
# AsyncHgetall
描述
执行redis操作,获取key的value,相当于redis中执行命令:hgetall key
参数
参数名 数据类型 说明 dbName str redis db名字,名字对应MCStudio中新增redis实例的实例名称 key str redis中的key callback function 回调函数,默认为空,函数输入参数是redis key对应的值,是个dict,它在主线程执行。若redis操作抛出异常,则callback输入参数是None。若没有回调,则传入None 返回值
无
示例
import apolloCommon.extraRedisPool as extraRedisPool
def Cb1(t):
print "cb", t
extraRedisPool.InitDB('extra_redis1', 30) #建立连接池
extraRedisPool.AsyncHgetall('extra_redis1', 'player_123', Cb1)
extraRedisPool.Finish()
# AsyncMget
描述
执行redis操作,获取多个key的值,相当于redis中执行命令:mget key1 key2 ...
参数
参数名 数据类型 说明 dbName str redis db名字,名字对应MCStudio中新增redis实例的实例名称 keys list/tuple 多个redis key callback function 回调函数,默认为空,函数输入参数redis操作返回值, 是个列表,每个元素对应单个redis key的值,它在主线程执行。若redis操作抛出异常,则callback输入参数是None 返回值
无
示例
import apolloCommon.extraRedisPool as extraRedisPool
def Cb1(t):
print "cb", t
extraRedisPool.InitDB('extra_redis1', 30) #建立连接池
keys = ('player_121', 'player_122')
extraRedisPool.AsyncMget('extra_redis1', keys, Cb1)
extraRedisPool.Finish()
# AsyncSet
描述
执行redis操作,设置key的值为value,相当于redis中执行命令:set key value
参数
参数名 数据类型 说明 dbName str redis db名字,名字对应MCStudio中新增redis实例的实例名称 key str redis中的key value str redis中key的值 callback function 回调函数,默认为空。函数输入参数是redis操作返回值,True表示设置成功,False失败。 若redis操作抛出异常,则callback输入参数是None。若没有回调,则传入None 返回值
无
示例
import apolloCommon.extraRedisPool as extraRedisPool
extraRedisPool.InitDB('extra_redis1', 30) #建立连接池
extraRedisPool.AsyncSet('extra_redis1', 'player_123', "{'name':'nickname'}")
extraRedisPool.Finish()
# Finish
描述
等待redis db线程池退出,会等待线程池中所有异步任务执行完毕后退出
返回值
无
示例
import apolloCommon.extraRedisPool as extraRedisPool
extraRedisPool.InitDB('extra_redis1', 30) #建立连接池
#回调,可以获取player的信息。这里只是打印结果。
def Cb1(t):
print "cb", t
#第一个参数是redis.StrictRedis实例。
def GetValueFromKey(conn, key):
return conn.get(key)
#插入一个任务,从redis中获取uid为123玩家的信息。
extraRedisPool.AsyncFuncWithKey('extra_redis1', GetValueFromKey, 'player_123', Cb1, 123)
extraRedisPool.Finish()
# InitDB
描述
初始化redis连接池,要求在MCStudio的“服务器配置”中“新增redis实例”
参数
参数名 数据类型 说明 dbName str redis实例名字,对应MCStudio中redis“实例名称”配置 poolSize int 连接池大小 返回值
无
示例
import apolloCommon.extraRedisPool as extraRedisPool
extraRedisPool.InitDB('extra_redis1', 30)
这里是mongo扩展线程池的一些接口
# mongo连接池扩展
# AsyncExecute
描述
添加一个异步mongo任务
参数
参数名 数据类型 说明 dbName str mongo db名字,名字在deploy.json中extra_mongo下配置,具体参见InitDB备注说明 collection str mongo中的一个集合,相同集合的所有操作串行执行,不同集合操作并行执行 func function mongo异步任务,可以没有返回值。该任务和主线程会并行执行,要求任务是线程安全的。第一个参数是一个mongo长连接,是pymongo.MongoClient连接池实例中的一个连接 callback function 回调函数,只有一个输入参数,它在主线程执行。func的返回值会是callback的实参。若func抛出异常,则callback输入参数是None。若没有回调,则传入None *args *args func的非关键字参数 **kwargs **kwargs 暂无用,预留用 返回值
无
示例
import apolloCommon.extraMongoPool as extraMongoPool
extraMongoPool.InitDB('mongo_test1', 32)
def Insert(col):
postData = {
'title': 'Python and MongoDB',
'content': 'PyMongo is fun, you guys',
'author': 'Scott'
}
col.insert_one(postData)
def Cb(t):
print "cb", t
#添加异步任务。
extraMongoPool.AsyncExecute('mongo_test1', 'test_col', Insert, Cb)
extraMongoPool.Finish()
# AsyncExecuteWithOrderKey
描述
添加一个异步mongo任务。同async_execute区别是,可以显示设置orderKey
参数
参数名 数据类型 说明 dbName str mongo db名字,名字在deploy.json中extra_mongo下配置,具体参见InitDB备注说明 collection str mongo中的一个集合 func function mongo异步任务,可以没有返回值。该任务和主线程会并行执行,要求任务是线程安全的。第一个参数是一个mongo长连接,是pymongo.MongoClient连接池实例中的一个连接,其他参数是*args orderKey str/int 相同的orderKey会顺序执行,不同的orderKey会并行执行 callback function 回调函数,只有一个输入参数,它在主线程执行。func的返回值会是callback的实参。若func抛出异常,则callback输入参数是None。若没有回调,则传入None *args *args func的非关键字参数 **kwargs **kwargs 暂无用,预留 返回值
无
示例
import apolloCommon.extraMongoPool as extraMongoPool
extraMongoPool.InitDB('mongo_test1', 32)
def Insert(col):
postData = {
'title': 'Python and MongoDB',
'content': 'PyMongo is fun, you guys',
'author': 'Scott'
}
col.insert_one(postData)
def Cb(t):
print "cb", t
#添加异步任务
#下面操作相当于:apolloCommon.AsyncExecute('mongo_test1', 'test_col', Insert, Cb)
apolloCommon.AsyncExecuteWithOrderKey('mongo_test1', 'test_col', Insert, 'test_col', Cb)
#添加相同任务,两个任务顺序执行
apolloCommon.AsyncExecuteWithOrderKey('mongo_test1', 'test_col', Insert, 'test_col', Cb)
apolloCommon.Finish()
# Finish
描述
等待mongo线程池退出,会等待线程池中所有异步任务执行完毕后退出
返回值
无
示例
import apolloCommon.extraMongoPool as extraMongoPool
extraMongoPool.Finish()
# InitDB
描述
初始化mongo连接池。可以支持多个mongo实例,它可以同“mongo连接池”一起使用。MCStudio打开配置文件目录,在deploy.json文件中配置extra_mongo,配置方法参见备注
参数
参数名 数据类型 说明 dbName str mongo db名字,名字在deploy.json中extra_mongo下配置,比如示例配置中 “mongo_test1” poolSize int 连接池大小 返回值
无
备注
deploy.json部分配置的示例如下:
"mongo": { "database": "test", "host": "127.0.0.1", "password": "test", "port": 27017, "user": "test" }, "extra_mongo":{ "testname1" : { "database": "mongo_test1", "host": "127.0.0.2", "password": "test", "port": 27017, "user": "test" }, "testname2" : { "database": "mongo_test2", "host": "127.0.0.3", "password": "test", "port": 27017, "user": "test" } },
示例
import apolloCommon.extraMongoPool as extraMongoPool
extraMongoPool.InitDB('mongo_test1', 30)
这里是公共的一些接口
# 通用
# ChangeDatabaseSlowLogLimit
描述
修改数据库连接池慢请求报警日志限定时间
参数
参数名 数据类型 说明 db str 数据库连接池类型,mysql/redis/mongo interval float 慢请求限制时间,单个请求返回时间超过这个值就会记录慢请求日志,单位秒,mysql和mongo默认配置值为1.0秒,redis默认配置为0.1秒 返回值
数据类型 说明 bool 执行结果 示例
import apolloCommon.commonNetgameApi as commonNetgameApi
suc = commonNetgameApi.ChangeDatabaseSlowLogLimit("mysql", 0.1)
print "ChangeDatabaseSlowLogLimit for mysql suc=%s" % suc
# CheckNameValid
描述
判定一个输入的string是否通过了命名库敏感词检查,没有敏感词返回1,存在敏感词返回0
参数
参数名 数据类型 说明 name str 需要做敏感词检查的string 返回值
数据类型 说明 int 1代表没有敏感词,0代表存在敏感词 示例
import apolloCommon.commonNetgameApi as commonNetgameApi
isOk = commonNetgameApi.CheckNameValid("xxxxxx")
if not isOk:
print "输入中存在敏感词"
return
# CheckWordsValid
描述
判定一个输入的string是否通过了通用库敏感词检查,没有敏感词返回1,存在敏感词返回0
参数
参数名 数据类型 说明 words str 需要做敏感词检查的string 返回值
数据类型 说明 int 1代表没有敏感词,0代表存在敏感词 示例
import apolloCommon.commonNetgameApi as commonNetgameApi
isOk = commonNetgameApi.CheckSensitiveByName("xxxxxx")
if not isOk:
print "输入中存在敏感词"
return
# CloseAsyncTaskSlowCheck
描述
停止每帧检查异步线程池中的任务
返回值
数据类型 说明 bool 执行结果 示例
import apolloCommon.commonNetgameApi as commonNetgameApi
commonNetgameApi.CloseAsyncTaskSlowCheck()
# DumpAsyncTaskPool
描述
打印当前异步线程池中的正在排队和执行中的任务信息
返回值
数据类型 说明 bool 执行结果 示例
import apolloCommon.commonNetgameApi as commonNetgameApi
commonNetgameApi.DumpAsyncTaskPool()
# GetApolloReviewStage
描述
获取游戏当前审核阶段
返回值
数据类型 说明 int 0 测试阶段,1 审核阶段 2 上线阶段 示例
import apolloCommon.commonNetgameApi as commonNetgameApi
reviewStage = commonNetgameApi.GetApolloReviewStage()
# GetModJsonConfig
描述
根据脚本根目录读取mod.json配置文件
参数
参数名 数据类型 说明 scriptRootName str python脚本的根目录名 返回值
数据类型 说明 dict mod.json里面的内容信息 示例
#目录结构
# |-developer_mods
# |- neteaseNpcLobbyDev
# mod.json
# |- neteaseNpcLobby
import apolloCommon.commonNetgameApi as commonNetgameApi
confDict = commonNetgameApi.GetModJsonConfig("neteaseNpcLobby")
print confDict["description"]#打印mod.json中description配置内容
#mod.json取出的字符串都是unicode编码。若是中文,需要手动转成UTF-8编码。转码方法如下:
npcName = confDict["name"].encode('utf-8')
# GetModJsonConfigByName
描述
读取基于脚本根目录的[pathFile]路径下的json格式配置文件
参数
参数名 数据类型 说明 scriptRootName str python脚本的根目录名 pathFile str 相对于python脚本的根目录的文件名(包括相对路径) 返回值
数据类型 说明 dict 对应目录下json文件里面的内容信息 示例
#目录结构
# |-developer_mods
# |- neteaseNpcLobbyDev
# mod.json
# |- neteaseNpcLobby
# |- modData
# skill1.json
import apolloCommon.commonNetgameApi as commonNetgameApi
confDict = commonNetgameApi.GetModJsonConfig("neteaseNpcLobby", "modData/skill1.json")
print confDict # 打印skill1.json文件的内容
#json取出的字符串都是unicode编码。若是中文,需要手动转成UTF-8编码。转码方法如下:
npcName = confDict["name"].encode('utf-8')
# GetModScriptRootDir
描述
获取脚本根目录的绝对路径
参数
参数名 数据类型 说明 scriptRootName str python脚本的根目录名 返回值
数据类型 说明 str 脚本根目录的绝对路径 示例
#目录结构
# |-developer_mods
# |- neteaseNpcLobbyDev
# mod.json
# |- neteaseNpcLobby
import apolloCommon.commonNetgameApi as commonNetgameApi
commonNetgameApi.GetModScriptRootDir("neteaseNpcLobby")
#结果:/home/fuzhu/netgame/app/template/lobby/lobby_lobby_2000000/developer_mods/neteaseNpcLobbyDev/
# GetServerType
描述
获取本服的服务器类型,对应MCStudio中配置:服务器配置->游戏配置->类型
返回值
数据类型 说明 str 服务器类型 示例
import apolloCommon.commonNetgameApi as commonNetgameApi
commonNetgameApi.GetServerType() #结果是:"gameBattleA"
# OpenAsyncTaskSlowCheck
描述
启动每帧检查异步线程池中的任务,并且打印执行时间超过指定时间且尚未完成的任务,此功能消耗较大,仅建议在测试阶段和遇到线上紧急问题时启用
参数
参数名 数据类型 说明 interval float 任务限制时间,单个任务进入异步线程池排队+执行时间超过此时间还没有完成的,会以warning日志的形式输出 返回值
数据类型 说明 bool 执行结果 示例
import apolloCommon.commonNetgameApi as commonNetgameApi
commonNetgameApi.OpenAsyncTaskSlowCheck(0.01)
# StartDatabaseProfile
描述
开始记录数据库连接池请求信息统计,启动后调用StopDatabaseMysqlProfile(db)即可获取两个函数调用之间数据库连接池请求记录信息
参数
参数名 数据类型 说明 db str 数据库连接池类型,mysql/redis/mongo 返回值
数据类型 说明 bool 执行结果 示例
import apolloCommon.commonNetgameApi as commonNetgameApi
commonNetgameApi.StartDatabaseProfile("mysql")
# 之后通过计时器或者其他触发方式调用StopDatabaseMysqlProfile
result = commonNetgameApi.StopDatabaseMysqlProfile("mysql")
for single in result:
action = single["action"]
if action == "executefunc":
print "do {} func={} orderKey={} cost={}s ret={}".format(action, single["func"], single["orderKey"], single["costTp"], single["ret"])
else:
print "do {} orderKey={} cost={}s ret={}".format(action, single["orderKey"], single["costTp"], single["ret"])
# StartYappiProfile
描述
开始启动服务端脚本性能分析,启动后调用StopYappiProfile(path)即可在路径path生成函数性能火焰图
返回值
数据类型 说明 bool 执行结果 示例
import apolloCommon.commonNetgameApi as commonNetgameApi
commonNetgameApi.StartYappiProfile()
modfunc()# 处理对应的逻辑
# 之后通过计时器或者其他触发方式调用StopYappiProfile
commonNetgameApi.StopYappiProfile()
# StopDatabaseMysqlProfile
描述
停止记录数据库连接池请求信息并输出统计结果,与StartDatabaseProfile(db)配合使用,输出结果为字典,具体见示例
参数
参数名 数据类型 说明 db str 数据库连接池类型,mysql/redis/mongo 返回值
数据类型 说明 list 数据库连接池请求统计信息,具体见示例,假如没有调用过StartDatabaseProfile,则返回为None 示例
import apolloCommon.commonNetgameApi as commonNetgameApi
commonNetgameApi.StartDatabaseProfile("mysql")
# 之后通过计时器或者其他触发方式调用StopDatabaseMysqlProfile
result = commonNetgameApi.StopDatabaseMysqlProfile("mysql")
for single in result:
action = single["action"]
if action == "executefunc":
print "do {} func={} orderKey={} cost={}s ret={}".format(action, single["func"], single["orderKey"], single["costTp"], single["ret"])
else:
print "do {} orderKey={} cost={}s ret={}".format(action, single["orderKey"], single["costTp"], single["ret"])
# StopYappiProfile
描述
停止服务端脚本性能分析并生成火焰图,与StartYappiProfile()配合使用
参数
参数名 数据类型 说明 fileName str 具体路径,相对于Apollo服务端启动目录的路径,默认为"flamegraph.svg",位于Apollo服务端启动目录下,自定义路径请确保文件后缀名为".svg" 返回值
数据类型 说明 bool 执行结果 示例
import apolloCommon.commonNetgameApi as commonNetgameApi
commonNetgameApi.StartYappiProfile()
modfunc()# 处理对应的逻辑
# 之后通过计时器或者其他触发方式调用StopYappiProfile
commonNetgameApi.StopYappiProfile()
# 世界
# AddRepeatedTimer
描述
添加服务端触发的定时器,重复执行
参数
参数名 数据类型 说明 delay float 延迟时间,单位秒 func func 定时器触发函数 *args *args 变长参数,可以不设置 **kwargs **kwargs 字典变长参数,可以不设置 返回值
数据类型 说明 timer 返回单次触发的定时器 示例
def doRepeatPrint(info):
print "doRepeatPrint", info
import apolloCommon.commonNetgameApi as commonNetgameApi
commonNetgameApi.AddRepeatedTimer(2.0, doRepeatPrint, "this is repeat timer")
# AddTimer
描述
添加服务端触发的定时器,非重复
参数
参数名 数据类型 说明 delay float 延迟时间,单位秒 func func 定时器触发函数 *args *args 变长参数,可以不设置 **kwargs **kwargs 字典变长参数,可以不设置 返回值
数据类型 说明 timer 返回单次触发的定时器 示例
def doOncePrint(info):
print "doOncePrint", info
import apolloCommon.commonNetgameApi as commonNetgameApi
commonNetgameApi.AddTimer(5.0, doOncePrint, "this is once timer")
# CancelTimer
描述
取消定时器
参数
参数名 数据类型 说明 timer timer对象 AddTimer和AddRepeatedTimer时返回的定时器对象 返回值
无
示例
import apolloCommon.commonNetgameApi as commonNetgameApi
commonNetgameApi.CancelTimer(timer)
# 玩家
# GetOnlineKey
描述
输入玩家uid,返回此玩家保存在redis中的在线标识的key
参数
参数名 数据类型 说明 uid int 玩家的uid 返回值
数据类型 说明 str 此玩家保存在redis中的在线标识的key;它是个hash表,包含两个hash key:serverid,proxyid,假如无法获取到或者只获取到proxyid获取不到serverid,说明此玩家当前不在线 示例
import apolloCommon.commonNetgameApi as commonNetgameApi
onlineKey = commonNetgameApi.GetOnlineKey(123)
# GetOnlineServerInfoOfMultiPlayers
描述
获取多个玩家在线信息
参数
参数名 数据类型 说明 uid list(int) 玩家的netease uid列表,列表不能超过100,若超过100,本api会抛出Exception callback function 回调函数,该函数会被异步执行。函数只需要一个参数,是list(dict)类型。每个dict包含的键以及含义说明:"uid":玩家的netease uid; "serverId":玩家所在lobby或game的服务器id, 若玩家不在线则为None;"proxyId":客户端连接的proxy服务器id, 若玩家不在线则为None 返回值
无
示例
def GetPlayersOnlineCb(args):
#若参数是:{["uid":123, "serverId" :2000000, "proxyId" :1000000},{"uid":234, "serverId" :None, "proxyId" :None}]
#参数含义:第一个玩家uid是123,玩家是在线的,所在lobby或game的服务器id是2000000,玩家连接的proxy服务器id是1000000;
# 第二个玩家玩家uid是234,玩家是离线的
print 'GetOnlineServerCb', args
import apolloCommon.commonNetgameApi as commonNetgameApi
commonNetgameApi.GetOnlineServerInfoOfMultiPlayers([123, 234], GetPlayersOnlineCb)
# GetOnlineServerInfoOfPlayer
描述
获取玩家在线信息
参数
参数名 数据类型 说明 uid int 玩家的netease uid,玩家的唯一标识 callback function 回调函数,该函数会被异步执行。函数只需要一个参数,是dict类型。dict包含的键以及含义说明:"uid":玩家的netease uid; "serverId":玩家所在lobby或game的服务器id, 若玩家不在线则为None;"proxyId":客户端连接的proxy服务器id, 若玩家不在线则为None 返回值
无
示例
def GetOnlineCb(args):
#若参数是:{"uid":123, "serverId" :2000000, "proxyId" :1000000}
#参数含义:玩家uid是123,玩家是在线的,所在lobby或game的服务器id是2000000,玩家连接的proxy服务器id是1000000
#若参数是:{"uid":123, "serverId" :None, "proxyId" :None}
#参数含义:玩家uid是123,玩家是离线的
print 'GetOnlineServerCb', args
import apolloCommon.commonNetgameApi as commonNetgameApi
commonNetgameApi.GetOnlineServerInfoOfPlayer(123, GetOnlineCb)
# GetWeekOnlineKey
描述
输入玩家uid,返回此玩家保存在redis中的本周的在线时间
参数
参数名 数据类型 说明 uid int 玩家的uid 返回值
数据类型 说明 str 此玩家保存在redis中的本周在线时间的key;它是个string,转化为int后就是此玩家本周在线时间的秒数
# ToPcUid
描述
将玩家的uid转换为pc平台的uid
参数
参数名 数据类型 说明 uid int 玩家的uid 返回值
数据类型 说明 int pc平台的玩家uid
# ToPeUid
描述
将玩家的uid转换为pe平台的uid
参数
参数名 数据类型 说明 uid int 玩家的uid 返回值
数据类型 说明 int pe平台的玩家uid
← 6-大厅与游戏服API 8-服务器通信 →