设为首页 收藏本站
查看: 648|回复: 0

[经验分享] 多线程之Openstack novnc 改造,缓解Nova压力

[复制链接]

尚未签到

发表于 2018-6-2 08:42:53 | 显示全部楼层 |阅读模式
#!/usr/bin/env python
#-*-coding:UTF-8-*-
"""
@Item   :  Socket learing
@Author :  William
@Group  :  DEV Group
@Date   :  2013-10-16
@Funtion:
"""
import sys,os,time,redis,traceback,json,threading,socket
from cloud.hsnovnc import utils
from cloud import log
LOG = log.get_logger(__name__)
class MySocket(object):
    def __init__(self, proto = 0):
        if proto == 0:
            self.sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
            self.sock.setblocking(True)
        else:
            self.sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
        self.sock.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)
    # The socket binding host and port
    def my_bind(self, host, port):
        try:
            self.sock.bind((host, port))
        except socket.error, e:
            LOG.error(e)
            return - 1
        return 0
    #listen TCP port ,default
    def my_listen(self, num = 1024):
        try:
            self.sock.listen(num)
        except socket.error, e:
            LOG.error(e)
            return - 1
        return 0
    #connect setting timeout
    def my_connect(self, host, port, time_out = -1):
        try:
            if time_out == -1:
                self.sock.setblocking(1)
            else:
                self.sock.settimeout(time_out)
            self.sock.connect((host, port))
        except socket.error, e:
            LOG.error(e)
            return - 1
        return 0
    #accept teturn client address
    def my_accept(self, time_out = -1):
        addr = []
        try:
            if time_out == -1:
                self.sock.setblocking(1)
            else:
                self.sock.settimeout(time_out)
            client_sock, addr = self.sock.accept()
        except socket.error, e:
            LOG.error(e)
        return client_sock, addr
    #recv setting timeout
    def my_recv(self, buf_size, time_out = -1):
        buf = ''
        try:
            if time_out == -1:
                self.sock.setblocking(1)
            else:
                self.sock.settimeout(time_out)
            buf = self.sock.recv(buf_size)
        except Exception, e:
            LOG.error(e)
        return buf
    #send setting timeout
    def my_send(self, buf, time_out = -1):
        try:
            if time_out == -1:
                self.sock.setblocking(1)
            else:
                self.sock.settimeout(time_out)
            send_len = self.sock.send(buf)
            return send_len
        except Exception, e:
            LOG.error(e)
            return - 1
    #close
    def my_close(self, time_out = -1):
        try:
            if time_out == -1:
                self.sock.setblocking(1)
            else:
                self.sock.settimeout(time_out)
            self.sock.close()
        except socket.error, e:
            LOG.error(e)
            return - 1
        return 0
class sock_thread(threading.Thread):
    def __init__(self, host, port,buf):
        threading.Thread.__init__(self)
        self.host = host
        self.port = port
        self.buf = buf
    def run(self):
        sock = MySocket()
        sock.my_bind(self.host, self.port)
        sock.my_listen(20)
        LOG.info('The socket has been connected')
        while True:
            conn, addr = sock.my_accept()
            while True:
                data = conn.recv(self.buf)
                if not data:
                    break
                else:
                    try:
                        data = json.loads(data)
                        if data['Node']['UUID']:
                            port =  utils.get_vnc_port(data['Node'].get('UUID',None))
                            data['Node']['port'] = port
                            LOG.info(json.dumps(data))
                            conn.send(json.dumps(data))
                        else:
                            conn.send()
                    except:
                        break
            conn.close()
        sock.my_close()
class socket_demo(object):
    def __init__(self):
        host  =  utils.get_net_ip()
        self.host =  host
        self.port = 10086
        self.buf = 4096
    def work(self):
        self.sock = sock_thread(self.host, self.port,self.buf)
        self.sock.start()
        time.sleep(0.5)
def init():
    st = socket_demo()
    st.work()

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-505990-1-1.html 上篇帖子: 制作Windows Server 2003/08 image详细步骤与OpenStack介绍 下篇帖子: openstack I版的搭建二
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表