1. 协程

   并发的解决方案:

    多进程

       多线程

       什么叫并发:看起来同时进行

    如何实现并发:切换+保存状态

    进程线程都是由操作系统调度的

协程:单线程下实现的并发,应用程序级别的切换,操作系统无法感知

    找到一个解决方案:1.在多个任务直接切换+保存状态

             2.检测应用程序的IO,实现遇到IO才切换。

并发提高效率:遇到IO的时候切换,才能提高效率,如果是计算,就不会提高效率。

    yield:能实现协程,但是不能提高效率。

    greenlet:需要pip3 install greenlet

from greenlet import greenlet

    g1=greenlet()

    g1.switch()

2.        gevent()

    安装:pip3 install gevent

from gevent import monkey

monkey.patch_all()         这两行代码写到文件的首部

import gevent

gevent.sleep(2)

    g1=gevent.spawn(eat,name='egon')

    g2=gevent.spawn(play,'alex')

g1.join()

g2.join()

3.         利用gevent写一个socket连接。

    单线程实现并发连接

4.         socketserver模块

    基于TCP

       import socketserver

       class MyTCPhandler(socketserver.BaseRequestHandler):            #通信

def hanler(self):

               while True:

           data=self.request.recv(1024)

           self.request.send(data.upper())

    if __name__=='__main__':

      socketserver.ForkingTCPServer      #windows不能使用多进程模式

      s=socketserver.ThreadingTCPServer(('127.0.0.1',8080),MyTCPhandler)

      s.server_forever()

    基于UDP:

   

import socketserver

       class MyTCPhandler(socketserver.BaseRequestHandler):            #通信

def hanler(self):

               client_data=self.request[0]

          self.request[1].sendto(client_data.upper(),self.client_address)

    if __name__=='__main__':

      socketserver.ForkingTCPServer      #windows不能使用多进程模式

      s=socketserver.ThreadingTCPServer(('127.0.0.1',8080),MyTCPhandler)

      s.server_forever()

5.   数据库介绍及mysql安装

   yum install mysql_server mysql -y

   

6.     mysql的基本管理

   mysql -h127.0.0.1 -uroot -p

mysqld --install

设置密码:

      mysqladmin -uroot -p password "123";

      破解密码:

   net stop mysql

   mysqld --skip-grant-tables 跳过授权表

      mysql -uroot -p

   update mysql.user set password=password('') where user='root' and host='localhost';

      flush privileges;

修改my.ini配置文件。

       在mysqld里面设置:skip-grant-tables

    [mysqld]

       [mysql]   mysql自带的客户端

    user='root'

    password='123'

       [client]    所有的客户端

       user='root'

    password='123'

建立账号:

      grant select,update on *.* to

7.      mysql的基本sql语句

库   增删改查

   表   增删改查

      记录   增删改查

8.        mysql的存储引擎

    innodb

9.        mysql的数据类型:

      数字类型:

      整型:默认有符号,指定无符号:unsigned

        int

        tinyint

        bigint

      浮点型

         float

         double

         decimal

      字符类型

      char

      varchar

   时间类型

      date

      time

      datetime

      timestamp

      year

   枚举类型

      enum

      setn  

      

Python学习笔记十一的更多相关文章

  1. python 学习笔记十一 SQLALchemy ORM(进阶篇)

    SqlAlchemy ORM SQLAlchemy是Python编程语言下的一款ORM框架,该框架建立在数据库API之上,使用关系对象映射进行数据库操作,简言之便是:将对象转换成SQL,然后使用数据A ...

  2. Python学习笔记十一:模块

    标准库(内置模块) time与datetime 模块 时间表示方式 1.时间戳 2.格式化的字符串 3.元组形式 时间戳就是一个秒数 x=time.time(),从1970年1月1日0时0分0秒到现在 ...

  3. python学习笔记十一:操作mysql

    一.安装MySQL-python # yum install -y MySQL-python 二.打开数据库连接 #!/usr/bin/python import MySQLdb conn = MyS ...

  4. python学习笔记(十一)redis的介绍及安装

    一.redis简介 1.redis是一个开源的.使用C语言编写的.支持网络交互的.可基于内存也可持久化的Key-Value数据库.       2.redis的官网地址,非常好记,是redis.io. ...

  5. python学习笔记(十一)-python程序目录工程化

    在一个程序当中,一般都会包含文件夹:bin.conf.lib.data.logs,以及readme文件. 所写程序存放到各自的文件夹中,如何进行串联? 首先,通过导入文件导入模块方式,引用其他人写好的 ...

  6. Python学习笔记(十一)

    Python学习笔记(十一): 生成器,迭代器回顾 模块 作业-计算器 1. 生成器,迭代器回顾 1. 列表生成式:[x for x in range(10)] 2. 生成器 (generator o ...

  7. Python学习笔记,day5

    Python学习笔记,day5 一.time & datetime模块 import本质为将要导入的模块,先解释一遍 #_*_coding:utf-8_*_ __author__ = 'Ale ...

  8. python3.4学习笔记(十一) 列表、数组实例

    python3.4学习笔记(十一) 列表.数组实例 #python列表,数组类型要相同,python不需要指定数据类型,可以把各种类型打包进去#python列表可以包含整数,浮点数,字符串,对象#创建 ...

  9. Go语言学习笔记十一: 切片(slice)

    Go语言学习笔记十一: 切片(slice) 切片这个概念我是从python语言中学到的,当时感觉这个东西真的比较好用.不像java语言写起来就比较繁琐.不过我觉得未来java语法也会支持的. 定义切片 ...

随机推荐

  1. 执行Git命令时出现各种 SSL certificate problem 的解决办法

    执行Git命令时出现各种 SSL certificate problem 的解决办法 来源  https://www.cnblogs.com/chenzc/p/5842932.html 比如我在win ...

  2. 超详细的Guava RateLimiter限流原理解析

    超详细的Guava RateLimiter限流原理解析  mp.weixin.qq.com 点击上方“方志朋”,选择“置顶或者星标” 你的关注意义重大! 限流是保护高并发系统的三把利器之一,另外两个是 ...

  3. (二) V4L2引入(含浅析UVC)

    title: V4L2引入(含浅析UVC) date: 2019/4/23 19:00:00 toc: true --- V4L2引入(含浅析UVC) 基本框架 V4L2全名是video for li ...

  4. 为Nexus配置阿里云代理仓库【转】

    Nexus默认远程仓库为https://repo1.maven.org/maven2/ 慢死,还常连不上. 可以添加阿里云代理仓库 URL:http://maven.aliyun.com/nexus/ ...

  5. NCE损失(Noise-Constrastive Estimation Loss)

    1.算法概述 假设X是从真实的数据(或语料库)中抽取的样本,其服从一个相对可参考的概率密度函数P(d),噪音样本Y服从概率密度函数为P(n),噪音对比估计(NCE)就是通过学习一个分类器把这两类样本区 ...

  6. TeamViewer 密码有关

    TeamViewer这个密码字母代表g不是q.

  7. MySQL启动出现The server quit without updating PID file错误解决办法

    启动mysql服务的时候报下面这个错: 之间网上搜了各种办法,有重新初始化的(这怎么可能,里面还有数据...),有修改启动脚本的等等,但是都没用. 其实解决办法非常简单粗暴,那就是把/etc/my.c ...

  8. express session 和 socketio session关联

    express session http是没有状态的协议, 需要web框架自己实现会话和会话管理工作. express框架有session插件可以使用. 见如下介绍: https://www.tuto ...

  9. Java方法参数的传递方式

    程序设计语言中,将参数传递给方法(或函数)有两种方法.按值传递(call by value)表示方法接受的是调用者提供的值:按引用调用(call by reference)表示方法接受的是调用者提供的 ...

  10. 域 搭建OU 组织单元

    以这个界面开始操作: 在 baidu.com 右键---新建----组织单位----北京分公司 在 baidu.com 右键---新建----组织单位----北京分公司 在北京分公司 和南京分公司下面 ...