- Update to lua 5.3.2
- Add skynet.coroutine lib
- Add new debug api to show c memory used
- httpc can use async dns query
- Redis driver support pipeline
- socket.send support string table, and rewrite redis driver
- socket.shutdown would abandon unsend buffer
- Improve some sproto api
- c memory doesn't count the memory allocated by lua vm
- some other bugfix (In multicast, socketchannel, etc)
- Improve and fix bug for sproto
- Add global short string pool for lua vm
- Add code cache mode
- Add a callback for mysql auth
- Add hmac_md5
- Sharedata support filename as a string
- Fix a bug in socket.httpc
- Fix a lua stack overflow bug in lua bson
- Fix a socketchannel bug may block the data steam
- Avoid dead loop when sending message to the service exiting
- Fix memory leak in netpack
- Improve DH key exchange implement
- Minor fix for socket
- Minor fix for multicast
- Update jemalloc to 4.0.4
- Update lpeg to 1.0.0
- Remove the size limit of cluster RPC message.
- Remove the size limit of local message.
- Add cluster.query and clsuter.register.
- Add an option of pthread mutex lock.
- Add skynet.core.intcommand to optimize skynet.sleep etc.
- Fix a memory leak bug in lua shared proto.
- snax.msgserver use string instead of lightuserdata/size.
- Remove some unused api in netpack.
- Raise error when skynet.send to 0.
- Improve lua serialization , support pairs metamethod.
- Bugfix : sproto (See commits log of sproto)
- Add user log service support (In config)
- Other minor bugfix (See commits log)
- Update lua 5.3.1
- Bugfix: skynet exit issue
- Bugfix: timer race condition
- Use atom increment in bson object id
- remove assert when write to a listen fd
- sproto encode doesn't use raw table api
- console support launch snax service
- Add cluster.snax
- Add nodelay in clusterd
- Merge sproto bugfix patch
- Move some skynet api into skynet.manager
- DNS support underscore
- Add logservice in config file for user defined log service
- skynet.fork returns coroutine
- Fix a few of bugs , see the commits log
- bugfix: httpc.get
- bugfix: seri lib stack overflow
- bugfix: udp send
- bugfix: udp address
- bugfix: sproto dump
- add: sproto default
- improve: skynet.wakeup (can wakeup skynet.call by raise an error)
- improve: skynet.exit (raise error when uncall response)
- remove: task overload warning
- move: some skynet api move into skynet.manager
- merge lua 5.3 offical bugfix
- improve sproto rpc api
- fix a deadlock bug when service retire
- improve cluster config reload
- add skynet.pcall for calling a function with
require
- better error log in loginserver
- sproto can share c struct between states
- udp api changed (use lua string now)
- fix memory leak in dns module
- Update sproto (bugfix)
- Add async dns query
- improve httpc
- Update examples client to lua 5.3
- Patch lua 5.3 to interrupt the dead loop (for debug)
- Update sproto (fix some bugs and support unordered map)
- Update lua from 5.2 to 5.3
- Add an online lua debugger
- Add sharemap as an example use case of stm
- Improve sproto for multi-state
- Improve mongodb driver
- Fix known bugs
- Add : mongo createIndex
- Update : sproto
- bugfix : sharedata check dirty flag when len/pairs metamethod
- bugfix : multicast
- Simplify the message queue
- Add create_index in mongo driver
- Fix a bug in big-endian architecture (sproto)
- Add UDP support
- Add IPv6 support
- socket send package can define a release method
- dispatch read before write in epoll
- remove snax queue mode
- Fix a bug in big-endian architecture
- Send to an invalid remote service will raise an error
- Bugifx: socket open address string
- Remove sha1 from mysqlaux
- merge lua and sproto bugfix , use crypt lib instead
- Fix a memory leak in socket
- minor bugfix in http module
- Add mysql client driver
- Bugfix : skynet.queue
- Bugfix : clear coroutine pool when GC
- hotfix : A bug introduce by 0.7.3
- Add some logs (warning) when overload
- Bugfix: crash on exit
- Bugfix : datacenter.wait
- Bugfix : error in forker coroutine
- Add skynet.term
- Accept socket report port
- sharedata can be update more than once
- bugfix: wakeup sleep should return BREAK
- bugfix: sharedatad load string
- bugfix: dataserver forward error msg
- Use sproto instead of cjson
- Add message logger
- Add hmac-sha1
- Some minor bugfix
- bugfix: only skynet.call response PTYPE_ERROR
- bugfix: datacenter.wakeup
- change struct msg name to avoid conflict in mac
- improve seri library
- add sharedata
- bugfix: service exit before init would not report back
- add skynet.response and check multicall skynet.ret
- skynet.newservice throw error when lanuch faild
- Don't check imported function in snax.hotfix
- snax service add change SERVICE_PATH and add it to package.path
- skynet.redirect support string address
- bugfix: skynet.harbor.link may block
- add skynet.harbor.queryname to query globalname
- add cluster.proxy
- add DEBUG command exit (send a message to lua service by DEBUG)
- add DEBUG command run (debug_console command inject)
- bugfix : socketchannel connect once
- bugfix : mongo driver
- Bugfix : httpd request
- Bugifx : http chunked mode
- Add : httpc
- timer support more than 497 days
- Bugfix : http module
- Bugfix : multicast local channel delete
- Bugfix : socket.read(fd)
- skynet.exit will quit service immediately.
- Add snax.gateserver, snax.loginserver, snax.msgserver
- Simplify clientsocket lib
- mongo driver support replica set
- config file support read from ENV
- add simple httpd (see examples/simpleweb.lua)
- Bugfix : invalid negative socket id
- Add optional TCP_NODELAY support
- Add worker thread weight
- Add skynet.queue
- Bugfix: socketchannel
- cluster can throw error
- Add readline and writeline to clientsocket lib
- Add cluster.reload to reload config file
- Add datacenter.wait
- Add SERVICE_NAME in loader
- Throw error back when skynet.error
- Add skynet.task
- Bugfix for last version (harbor service bugs)
- Optimize redis driver
compose_message
. - Add module skynet.harbor for monitor harbor connect/disconnect, see test/testharborlink.lua .
- cluster.open support cluster name.
- Add new api skynet.packstring , and skynet.unpack support lua string
- socket.listen support put port into address. (address:port)
- Redesign harbor/master/dummy, remove lots of C code and rewite in lua.
- Remove block connect api, queue sending message during connecting now.
- Add skynet.time()
- Bugfix : cluster (double free).
- Add socket.header() to decode big-endian package header (and fix the bug in cluster).
- Bugfix: lua mongo driver . Hold reply string before decode bson data.
- More check in bson decoding.
- Use big-endian for encoding bson objectid.
- Add cluster support
- Add single node mode
- Add daemon mode
- Bugfix: update lua-bson (signed 32bit int bug / check string length)
- Optimize timer
- Simplify message queue and optimize message dispatch
- Use jemalloc release 3.6.0
- Bugfix: check all the events already read after socket close
- Bugfix: socket data in gate service
- Bugfix: boundary problem in harbor service
- Bugfix: stdin handle is 0
- Rewrite malloc hook , use
pthread_getspecific
instead of__thread
to get current service handle. - Optimize global unique service query, rewrite
service_mgr
. - Add some snax api, snax.uniqueservice (etc.) , use independent protocol
PTYPE_SNAX
. - Add bootstrap lua script , remove some code in C .
- Use a lua loader to load lua service code (and set the lua environment), remove some code in C.
- Support preload a file before each lua serivce start.
- Add datacenter serivce.
- Add multicast api.
- Remove skynet.blockcall , simplify the implement of message queue.
- When dropping message queue (at service exit) , dispatcher will post an error back to the source of each message.
- Remove skynet.watch , monitor is not necessary for watching skynet.call . so simplemonitor.lua is move to examples.
- Remove the limit of global queue size (64K actived service limit before).
- Refactoring
skynet_command
.
- Socket channel should clear request queue when reconnect.
- Fix the issue that socket close may block the coroutine.
- Fix the issue that jemalloc api may crash on macosx (disable jemalloc on macosx).
- First release version.
- Make skynet from a private project to public.