日期: 2021 年 4 月 16 日

iOS appium元素定位,封装时候使用MobileBy和By结合

iOS:

1 from selenium.webdriver.common.by import By
2 class MobileBy(By):
3     IOS_PREDICATE = ‘-ios predicate string’
4     IOS_UIAUTOMATION = ‘-ios uiautomation’
5     IOS_CLASS_CHAIN = ‘-ios class chain’
6     ANDROID_UIAUTOMATOR = ‘-android uiautomator’
7     ANDROID_VIEWTAG = ‘-android viewtag’
8     ANDROID_DATA_MATCHER = ‘-android datamatcher’
9     ACCESSIBILITY_ID = ‘accessibility id’
10     IMAGE = ‘-image’
11     CUSTOM = ‘-custom’

android:

1 class By(object):
2     “””
3     Set of supported locator strategies.
4     “””
5
6     ID = “id”
7     XPATH = “xpath”
8     LINK_TEXT = “link text”
9     PARTIAL_LINK_TEXT = “partial link text”
10     NAME = “name”
11     TAG_NAME = “tag name”
12     CLASS_NAME = “class name”
13     CSS_SELECTOR = “css selector”

综合封装:

1 def find_element(self, *loc):
2     try:
3         # 元素可见时,返回查找到的元素;以下入参为元组的元素,需要加*
4         WebDriverWait(self.driver, 30).until(lambda driver: driver.find_element(*loc).is_displayed())
5         return self.driver.find_element(*loc)
6
7     except selenium.common.exceptions.NoSuchElementException:
8         # logging.warning(‘Can not find element: %s’ % loc[1])
9         self.log.myloggger(‘Can not find element: %s’ % loc[1], flag=2)
10         raise
11     except selenium.common.exceptions.TimeoutException:
12         self.log.myloggger(‘Can not find element: %s’ % loc[1], flag=2)
13         raise
14
15 def find_elements(self, *loc):
16     try:
17         WebDriverWait(self.driver, 30).until(lambda driver: driver.find_elements(*loc))
18         return self.driver.find_elements(*loc)
19
20     except selenium.common.exceptions.NoSuchElementException:
21         # logging.warning(‘Can not find element: %s’ % loc[1])
22         self.log.myloggger(‘Can not find element: %s’ % loc[1], flag=2)
23         self.get_screenshot()
24         raise

公共云和私有云的关系和区别

公共云和私有云

简单来说,云服务可以将企业所需的软硬件、资料都放到网络上,在任何时间、地点,使用不同的IT设备互相连接,实现数据存取、运算等目的。当前,常见的云服务有公共云(Public Cloud)与私有云(Private Cloud)两种。

公共云是*基础的服务,多个客户可共享一个服务提供商的系统资源,他们毋须架设任何设备及配备管理人员,便可享有专业的IT服务,这对于一般创业者、中小企来说,无疑是一个降低成本的好方法。公共云还可细分为3个类别,包括Software-as-a-Service, SaaS(软件即服务)、Platform-as-a-Service, PaaS(平台即服务)及Infrastructure-as-a-Service, IaaS(基础设施即服务)。   我们平日常用的Gmail、Hotmail、网上相册都属于SaaS的一种,主要以单一网络软件为主导;至于PaaS则以服务形式提供应用开发、部署平台,加快用户自行编写CRM、ERP等系统的时间,用户必须具备丰富的IT知识。

上述公共云服务成本较低,但使用灵活度有不足,不满足这种服务模式的中小企业,不妨考虑“IaaS” 的IT资源管理模式。IaaS架构主要通过虚拟化技术与云服务结合,直接提升整个IT系统的运作能力。IaaS让企业可以自由选择使用那些软、硬件及服务,中小企业都可根据行业的需要、发展规模,建设*适合自己的IT基建系统。

这种服务模式能为中小企业带来多重优势,其一、他们不必配备花费庞大的IT基建设备,却可享受同样专业的服务;其二、管理层可根据业务发展的规模、需求,调配所需的服务组合;其三、当有新技术出现时,企业可随时向服务提供商提出升级要求,不必为增加硬件而烦恼;其四、IaaS服务提供商拥有专业的顾问团队,中小企业可免却系统管理、IT支持方面的支出。

公共云服务提供商需遵守行业法规,但是大企业(如金融、保险行业)为了兼顾行业、客户私隐,不可能将重要数据存放到公共网络上,故倾向于架设私有云端网络。

私有云的运作形式,与公共云类似。然而,架设私有云却是一项重大投资,企业需自行设计数据中心、网络、存储设备,并且拥有专业的顾问团队。企业管理层必须充分考虑使用私有云的必要性,以及是否拥有足够资源来确保私有云正常运作。

与公有云相比,私有云的特点是:安全,私有云的服务对象被限制在企业内部,因此私有云的建设、运营和使用都是在企业内部完成,对外不提供公开接口,因此会相对安全。成本固定,云环境中通常是根据每单元存储收费的。用户只需根据服务水平协议对实际使用的部分付费,而不是根据分配的空间或者某一个标准。可用性,在用户需要的时候,空间需要能够被及时分配,并且要求能在使用完后及时地收回。服务质量,需要有详细的服务水平描述并严格参照执行。可衡量的标准可以用于定义用户能得到怎样的响应时间、恢复时间以及活动时间的支持。

负载均衡是什么,负载均衡技术主要应用在哪一领域?

什么是负载均衡(Load Balance)

由于目前现有网络的各个核心部分随着业务量的提高,访问量和数据流量的快速增长,其处理能力和计算强度也相应地增大,使得单一的服务器设备根本无法承担。在此情况下,如果扔掉现有设备去做大量的硬件升级,这样将造成现有资源的浪费,而且如果再面临下一次业务量的提升时,这又将导致再一次硬件升级的高额成本投入,甚至性能再卓越的设备也不能满足当前业务量增长的需求。

针对此情况而衍生出来的一种廉价有效透明的方法以扩展现有网络设备和服务器的带宽、增加吞吐量、加强网络数据处理能力、提高网络的灵活性和可用性的技术就是负载均衡(Load Balance)。

负载均衡技术主要应用

1、DNS负载均衡:*早的负载均衡技术是通过DNS来实现的,在DNS中为多个地址配置同一个名字,因而查询这个名字的客户机将得到其中一个地址,从而使得不同的客户访问不同的服务器,达到负载均衡的目的。DNS负载均衡是一种简单而有效的方法,但是它不能区分服务器的差异,也不能反映服务器的当前运行状态。

2、代理服务器负载均衡:使用代理服务器,可以将请求转发给内部的服务器,使用这种加速模式显然可以提升静态网页的访问速度。然而,也可以考虑这样一种技术,使用代理服务器将请求均匀转发给多台服务器,从而达到负载均衡的目的。

3、地址转换网关负载均衡:支持负载均衡的地址转换网关,可以将一个外部IP地址映射为多个内部IP地址,对每次TCP连接请求动态使用其中一个内部地址,达到负载均衡的目的。

4、协议内部支持负载均衡:除了这三种负载均衡方式之外,有的协议内部支持与负载均衡相关的功能,例如HTTP协议中的重定向能力等,HTTP运行于TCP连接的*高层。

5、NAT负载均衡:NAT(Network Address Translation 网络地址转换)简单地说就是将一个IP地址转换为另一个IP地址,一般用于未经注册的内部地址与合法的、已获注册的Internet IP地址间进行转换。适用于解决Internet IP地址紧张、不想让网络外部知道内部网络结构等的场合下。

6、反向代理负载均衡:普通代理方式是代理内部网络用户访问internet上服务器的连接请求,客户端必须指定代理服务器,并将本来要直接发送到internet上服务器的连接请求发送给代理服务器处理。反向代理(Reverse Proxy)方式是指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给internet上请求连接的客户端,此时代理服务器对外就表现为一个服务器。反向代理负载均衡技术是把将来自internet上的连接请求以反向代理的方式动态地转发给内部网络上的多台服务器进行处理,从而达到负载均衡的目的。

7、混合型负载均衡:在有些大型网络,由于多个服务器群内硬件设备、各自的规模、提供的服务等的差异,我们可以考虑给每个服务器群采用*合适的负载均衡方式,然后又在这多个服务器群间再一次负载均衡或群集起来以一个整体向外界提供服务(即把这多个服务器群当做一个新的服务器群),从而达到*佳的性能。我们将这种方式称之为混合型负载均衡。此种方式有时也用于单台均衡设备的性能不能满足大量连接请求的情况下。

Appium 搭建 IOS

1、 安装Xcode

%title插图%num

xcode是苹果的一个开发工具,我们主要使用xocde自带的ios模拟器,在模拟器上进行iOS app的自动化测试。
打开MAC机上的APP Strore,搜索Xcode,进行安装或者更新,注意观察下xcode的更新日志,上面有写支持的iOS SDK版本。

2、 安装JDK
默认安装JDK
编辑环境变量文件
vi ~/.bash_profile
编辑后生效
source ~/.bash_profile
.bash_profile文件内容
JAVA_HOME=”/Library/Java/JavaVirtualMachines/jdk1.7.0_80.jdk/Contents/Home/”
PATH=”PATH:PATH:JAVA_HOME/bin”
export JAVA_HOME
export PATH

3、 安装homebrew
brew是mac上一个软件管理工具,通过它可以在终端输入命令安装各种软件包
打开https://brew.sh/

%title插图%num

将地址拷贝到终端进行安装
(brew list列出已安装的软件)

4、 安装libimobiledevice
主要是第三方访问iOS设备的接口封装
brew install –HEAD libimobiledevice

5、 安装ideviceinstaller
用于给iOS设备安装卸载应用或者备份应用
brew install –HEAD ideviceinstaller

6、 安装ios-webkit-debug-proxy
在做iOS的h5页面的时候,肯定会需要去做webview调试来进行代码调试,而iOS webview调试需要区分真机和模拟器,因为具体的实现原理不一样的,模拟器使用 remote debugger,可以直接通过safari远程调试,而真机使用 ios-webkit-debugger-proxy去远程调试的。
注意,测试包必须要使用develop证书打包,才可以进行真机调试。
通过如下命令进行安装
brew install ios-webkit-debug-proxy

安装之后运行如下命令查看是否能够调起ios-webkit-debug-proxy
ios_webkit_debug_proxy -c XXXXXXXXXX:27753 -d XXXXXXXXXX表示设备UDID

运行上述命令发现报错如下:
Could not connect to lockdownd. Exiting.: Permission denied
通过查找资料,发现网上大部分的解决方案是执行如下命令:
sudo chmod -R 777 /var/db/lockdown/

appium如何启动ios-webkit-debug-proxy
发现ios-webkit-debug-proxy可以通过设置DesiredCapabilities来调起,代码如下:
cap.setCapability(“startIWDP”,true);

7、 安装maven
默认安装maven
配置环境变量:
MAVEN_HOME=”/Users/young/Documents/dev/apache-maven”
然后在PATH变量*后追加:$MAVEN_HOME/bin
*后在输入 export MAVEN_HOME

8、 安装android sdk
默认安装android-sdk
配置环境变量:
ANDROID_HOME=”/Users/young/Documents/dev/android-sdk-macosx/”
在PATH变量后续追加:
:ANDROIDHOME/tools:ANDROIDHOME/tools:ANDROID_HOME/platform-tools
*后要export ANDROID_HOME
完整的.bash_profile内容(包含了JAVA、Android和Maven的环境变量配置):
ANDROID_HOME=”/Users/young/Documents/Dev/android-sdk-macosx/”
JAVA_HOME=”/Library/Java/JavaVirtualMachines/jdk1.7.0_79.jdk/Contents/Home/”
MAVEN_HOME=”/Users/young/Documents/Dev/apache-maven”
PATH=”PATH:PATH:JAVA_HOME/bin:ANDROIDHOME/tools:ANDROIDHOME/tools:ANDROID_HOME/platform-tools:$MAVEN_HOME/bin”
export JAVA_HOME
export ANDROID_HOME
export MAVEN_HOME
export PATH

9、 安装node
brew install node
检查版本node -v

10、 安装npm
是一个NodeJS包管理和分发工具,已经成为了非官方的发布Node模块(包)的标准。
brew install npm

11、 安装appium
npm install -g appium
或者
npm install cnpm -g –registry=https://registry.npm.taobao.org
npm view appium versions #查看appium所有的版本号

12、 安装ios-deploy
是一个使用命令行安装ios app到连接的设备的工具,原理是根据os x命令行工程调用系统底层函数,获取连接的设备、查询/安装/卸载app。
npm install -g ios-deploy

13、 安装appium-doctor
是一个用于验证appium安装环境的工具,可以诊断出Node/iOS/Android环境配置方面的常见问题。
npm install appium-doctor -g
之后执行 appium-doctor 查看环境

%title插图%num

14、 安装WebDriverAgent(WDA)
如果是模拟器测试,不需要安装WDA,如果用真机一定要安装WDA
前提:电脑必须安装了Carthage
可以通过brew install Carthage
或者通过github下载pkg文件直接安装(源码安装可能会报错)https://github.com/Carthage/Carthage/releases

WebDriverAgent安装步骤:
1.进入WebDriverAgent
方式一:
从github上下载代码
git clone https://github.com/facebook/WebDriverAgent
用此方法安装,在appium执行的时候,要加
“xcodeOrgId”: “”,
“xcodeSigningId”: “iPhone Developer” 这两个参数,
TeamID 在 https://developer.apple.com/account/ 里左侧的 Member ship 中找到

%title插图%num

例如:
{
“platformName”: “iOS”,
“platformVersion”: “10.3”,
“deviceName”: “test”,
“automationName”: “XCUITest”,
“app”: “/Users/automation/test/VWallet.ipa”,
“bundleId”: “com.xiaoV.conchBeta”,
“udid”: “ab2ac6b5e375211d5bd8e8e3eedeb15704759390”,
“xcodeOrgId”: “6XXXXXXXXX”,
“xcodeSigningId”: “iPhone Developer”
}

方式二:
cd /Applications/Appium.app/Contents/Resources/app/node_modules/appium/node_modules/appium-xcuitest-driver/WebDriverAgent

%title插图%num

目录在appium安装目录下,具体路径参照自己的路径,可以通过find命令查找

2.在当前目录下执行脚本
sh ./Scripts/bootstrap.sh

3.编译WebDriverAgent.xcodeproj
双击打开当前目录下的WebDriverAgent.xcodeproj文件(工程文件在第1步的目录下)

注意:build时需要指定一个Development team,可以用个人Apple ID账号,生成个人证书和team(在Xcode->Preferences->Account中配置),也可以利用开发者账号。

%title插图%num

%title插图%num

%title插图%num

PROJECT->WebDriverAgent、TARGETS->WebDriverAgentLib和WebDriverAgentRunner的Signing使用个人的证书和Team(画黑色横线的部分)

%title插图%num
TARGETS->WebDriverAgentLib和WebDriverAgentRunner的Product Bundle Identifier使用一个新名字,因为Bundle ID不能重复

%title插图%num
点击Product->Build,将工程文件编译一下

4.测试一下,然后手机上信任证书
安装方式一:
还是在WebDriverAgent目录下,执行下面的命令来测试一下是否生效了
xcodebuild -project WebDriverAgent.xcodeproj -scheme WebDriverAgentRunner -destination ‘id=你的udid’ test
例如:
xcodebuild -project WebDriverAgent.xcodeproj -scheme WebDriverAgentRunner -destination ‘id=3340586f5abe813300530112f2238ac9b7e31e88’ test
如果没有报错证明安装成功,同时手机上会安装一个WebDriverAgent软件

%title插图%num

说明:如果编译WebDriverAgent时使用了自己的证书,需要再手机设置->通用里信任一下证书

安装方式二:
菜单栏选择目标设备

%title插图%num
Scheme选择WebDriverAgentRunner

%title插图%num
*后运行 Product -> Test
一切正常的话,手机上会出现一个无图标的WebDriverAgent应用,启动之后,马上又返回到桌面。这是很正常的不要奇怪。
此时控制台界面可以看到设备的IP。如果看不到的话,使用这种方法打开

%title插图%num

通过上面给出的IP和端口,加上/status合成一个url地址。例如http://10.0.0.1:8100/status,然后浏览器打开。如果出现一串JSON输出,说明WDA安装成功了。

测试WebDriverAgent时遇到的问题1:
Testing failed:
Signing for “WebDriverAgentRunner” requires a development team. Select a development team in the project editor.
Code signing is required for product type ‘UI Testing Bundle’ in SDK ‘iOS 10.3’
需要下图的这两个target都配置一下debug的证书和配置文件,然后编译

%title插图%num

测试WebDriverAgent时遇到的问题2:
Testing failed:
Test target WebDriverAgentRunner encountered an error (Early unexpected exit, operation never finished bootstrapping – no restart will be attempted)

解决方法:
进入手机的设置->通用->描述文件与设备管理,信任编译WebDriverAgent时选择的证书
然后再执行该命令就可以了

%title插图%num
15、 安装IOS模拟器
打开已经安装好的xcode(位于/Applactions/Xcode),如图

%title插图%num

然后选择Create a new Xcode Project,接下来按照图操作

%title插图%num

%title插图%num

%title插图%num

%title插图%num

%title插图%num

然后会是这个样子

%title插图%num

如果你的xode中存在iOS SDK,那么点击

%title插图%num

这个地方会弹出可用的模拟器,比如我的

%title插图%num

此时点击这个iPhone 6就会由这个模拟器来执行这个project。点击这个三角符号,进行运行操作

%title插图%num

注意观察

%title插图%num

IOS 模拟器启动了

%title插图%num

如果没有ios SDK可以在这里下载更多的ios simulator

%title插图%num

点击之后如图

%title插图%num

注意:根据自己需求来下载相应的iOS SDK。
另外你还可以将ios模拟器固定在DOCK,这样每次启动ios模拟器可以从dock上点击启动即可,如下图所示:

%title插图%num

三合一

三合一

三合一
描述如何只用一个数组来实现三个栈。

实现push(stackNum, value)、pop(stackNum)、isEmpty(stackNum)、peek(stackNum)方法。stackNum表示栈下标,value表示压入的值。

构造函数会传入一个stackSize参数,代表每个栈的大小。

示例1:

输入:
[“TripleInOne”, “push”, “push”, “pop”, “pop”, “pop”, “isEmpty”]
[[1], [0, 1], [0, 2], [0], [0], [0], [0]]
输出:
[null, null, null, 1, -1, -1, true]
说明:当栈为空时`pop, peek`返回-1,当栈满时`push`不压入元素。
示例2:

输入:
[“TripleInOne”, “push”, “push”, “push”, “pop”, “pop”, “pop”, “peek”]
[[2], [0, 1], [0, 2], [0, 3], [0], [0], [0], [0]]
输出:
[null, null, null, null, 2, 1, -1, -1]
示例代码:

class TripeInOne(object):
def __init__(self, stack_size):
self.stack_size = stack_size
self.tripe_stack = [[] for _ in range(3)]

def push(self, stack_num, value):
if len(self.tripe_stack[stack_num]) < self.stack_size:
self.tripe_stack[stack_num].append(value)
else:
return -1

def pop(self, stack_num):
if len(self.tripe_stack[stack_num]) != 0:
return self.tripe_stack[stack_num].pop()
else:
return -1

def peek(self, stack_num):
if len(self.tripe_stack[stack_num]) != 0:
return self.tripe_stack[stack_num][-1]
else:
return -1

def is_empty(self, stack_num):
return self.tripe_stack[stack_num] == []

if __name__ == ‘__main__’:
obj = TripeInOne(10)
print(obj.is_empty(0))
obj.push(0, 3)
obj.push(0, 2)
obj.push(0, 1)
print(obj.is_empty(0))
print(obj.peek(1))
print(obj.peek(0))
print(obj.pop(0))
print(obj.peek(0))
运行结果:

%title插图%num

基于Python的简易计算器实现

基于Python的简易计算器实现

基于Python的简易计算器实现
一、关键代码
def click(num):
global op
op=op+str(num)
iptext.set(op)

def evaluate():
global op
output=str(eval(op))
iptext.set(output)

def clearDisplay():
global op
op=””
iptext.set(op)

cal=Tk()
cal[“bg”]=“SteelBlue”
cal.title(“计算器”)
op=””

iptext=StringVar()
iparea=Entry(cal,font=(‘large,_font’,15,‘bold’),bd=10,justify=“right”,insertwidth=4,textvariable=iptext).grid(columnspan=10)

bt7=Button(cal,font=(‘arial’,15,‘bold’),command=lambda:click(7),bg=“PowderBlue”,text=“7”,bd=5,padx=15,pady=10).grid(row=1,column=0)

二、实现截图

%title插图%num%title插图%num

Web SSH 客户端工具

Web SSH 客户端工具

webssh简介
如何在浏览器web页面登录我们的linux机器,这个工具是使用Python开发

官网:https://pypi.org/project/webssh/

webssh这个工具可以干啥??

在linux机器上安装python环境,并且使用命令pip3 install webssh,装上这个模块

功能
支持SSH密码验证,包括空密码。
支持SSH公钥认证,包括DSA RSA ECDSA Ed25519密钥。
支持加密密钥。
支持两要素身份验证(基于时间的一次性密码)
支持全屏终端。
终端窗口可调整大小。
自动检测ssh服务器的默认编码。
现代浏览器支持Chrome,Firefox,Safari,Edge,Opera。

1,安装
pip3 install webssh

[root@centos8 ~]# pip3 install webssh
WARNING: Running pip install with root privileges is generally not a good idea. Try `pip3 install –user` instead.
Collecting webssh
Downloading https://files.pythonhosted.org/packages/cf/62/70ec57c40f1eb6d789a19f7af3075d14ad09cf283482d6ae6acfc75be1ea/webssh-1.5.3.tar.gz (182kB)
100% |████████████████████████████████| 184kB 38kB/s
Collecting tornado>=4.5.0 (from webssh)
Downloading https://files.pythonhosted.org/packages/01/d1/8750ad20cbcefb499bb8b405e243f83c2c89f78d139e6f8c8d800640f554/tornado-6.1-cp36-cp36m-manylinux1_x86_64.whl (427kB)
100% |████████████████████████████████| 430kB 24kB/s
Requirement already satisfied: paramiko>=2.3.1 in /usr/lib/python3.6/site-packages (from webssh)
Requirement already satisfied: bcrypt>=3.1.3 in /usr/lib64/python3.6/site-packages (from paramiko>=2.3.1->webssh)
Requirement already satisfied: cryptography>=1.5 in /usr/lib64/python3.6/site-packages (from paramiko>=2.3.1->webssh)
Requirement already satisfied: pynacl>=1.0.1 in /usr/lib64/python3.6/site-packages (from paramiko>=2.3.1->webssh)
Requirement already satisfied: pyasn1>=0.1.7 in /usr/lib/python3.6/site-packages (from paramiko>=2.3.1->webssh)
Requirement already satisfied: cffi>=1.1 in /usr/lib64/python3.6/site-packages (from bcrypt>=3.1.3->paramiko>=2.3.1->webssh)
Requirement already satisfied: six>=1.4.1 in /usr/lib/python3.6/site-packages (from bcrypt>=3.1.3->paramiko>=2.3.1->webssh)
Requirement already satisfied: idna>=2.1 in /usr/lib/python3.6/site-packages (from cryptography>=1.5->paramiko>=2.3.1->webssh)
Requirement already satisfied: asn1crypto>=0.21.0 in /usr/lib/python3.6/site-packages (from cryptography>=1.5->paramiko>=2.3.1->webssh)
Requirement already satisfied: pycparser in /usr/lib/python3.6/site-packages (from cffi>=1.1->bcrypt>=3.1.3->paramiko>=2.3.1->webssh)
Installing collected packages: tornado, webssh
Running setup.py install for webssh … done
Successfully installed tornado-6.1 webssh-1.5.3

2,启动

#直接运行wssh,使用默认8888端口
wssh

通过绑定IP地址和端口启动
wssh –address=’192.168.43.150′ –port=8888
wssh –address=’0.0.0.0′ –port=8888

通过绑定IP地址和端口启动,只允许本地地址访问
wssh –address=’127.0.0.1′ –port=8888

[root@centos8 ~]# wssh –address=’192.168.43.150′ –port=8888 &
[1] 1393
[root@centos8 ~]# [I 210414 17:05:35 settings:125] WarningPolicy
[I 210414 17:05:35 main:39] Listening on 192.168.43.150:8888 (http)

3,打开web使用
http://192.168.43.150:8888/

%title插图%num

公有云迁移,需要考虑的问题

许多公司认为公有云是托管所有应用的*佳场所,但情况并非总是如此。在您享用云带来的低成本之前,请确保该举措的确会带来成本效益,由于公有云的可扩展性、速度和即付即用模式,对许多企业来说,公有云是一个很有吸引力的选择。但是这些好处并不适用于所有的工作——实际上,一些应用可能在云中表现不佳或成本更高。

这意味着,在将应用迁移到公共基础设施即服务(IaaS)平台之前,您需要确保此举能提供业务价值。

首先,了解您要迁移到云上的动机。您想要更低的成本吗?您需要更多的灵活性吗?一些企业很快地就转移到云上,只因为他们认为应该这样做,这可能会导致将来发生问题。

在决定大规模将应用迁移到公有云之前,需要考虑以下三个问题:

如何选择要迁移的应用?

评估您的应用,并检查其需求——无论是性能还是合规性,以确定它是否是公有云的合适候选者。检查应用是否有任何特定的网络需求或依赖项。除非您还同时迁移应用所依赖的系统,包括数据库,否则延迟可能是一个问题。此外,在将应用迁移到云端之前,请查看应用的设计;例如,经常读取和写入存储系统的应用可能会导致更多的处理费用。一般来说,“突发”或频繁出现高峰需求的应用非常适合于公有云,而运行在更一致、可预测基础上的应用在本地可能会更好。

云供应商提供诸如AzureCloudMigrationAssessment和AmazonWebServices(AWS)ApplicationDiscoveryService等工具来简化评估过程。AWS,Azure和Google还提供定价计算器来估算云成本。

另外,确定您选择的云供应商是否符合您对安全性和合规性的要求。看看他们的数据中心在哪里,特别是如果您有敏感数据需要遵守严格的合规性标准的时候。

应该采用哪种迁移方式?

在确定要迁移的应用之后,就要确定迁移方法。两个常见的选项是rehost(重新托管),也称为lift-and-shift,以及refactor(重构),也称为rearchitect(重新架构)。

由于开发人员不必更改应用的架构或设计,因此lift-and-shift过程所需的时间比重构的时间要少,因为它们只是按原样移动。但是,尽管lift-and-shift是一种更简单的方法,但它也有缺点。例如,如果您将应用迁移到IaaS而无需任何修改,那么可能无法利用关键的云特性:自动缩放。其结果是,这些应用的运行方式仍然与本地部署的系统相同——在高峰期,企业将为实际使用的云存储和计算资源付出更多的代价。

因此,对于一些旧的应用来说,重新构建或重构是一个更好的选择——即使它更耗时且成本高昂。另一方面,lift-and-shift*适合云灾难的恢复。

不要太快地将应用迁移到云上——从*适配于云并且敏感数据*少的应用开始。在运行一个试点之后,测试应用,了解该过程,然后再转移到更关键的应用上。

有哪些云迁移工具可供选择?

迁移是一个复杂的过程,伴随着风险和潜在的高成本。云供应商和第三方工具都可以帮助企业完成此过程。例如,MicrosoftAssessment和PlanningToolkit可以帮助IT团队将应用迁移到MicrosoftAzure,而像Cloudyn和CloudVelox这样的第三方工具也可以发挥作用。

如果企业需要将大量的数据迁移到云端,则还可以执行脱机数据迁移。这需要企业将其数据存储到物理磁盘上,然后将磁盘运送给云供应商。虽然这种方法可能看起来有些老套,但如果您有TB级的数据,那么它可能比通过网络的迁移更具成本效益。
————————————————

原文链接:https://blog.csdn.net/duozhishidai/article/details/103454633

python在内存中处理图片

python在内存中处理图片

目录

python在内存中处理图片

1. 获取gif图片*帧,添加文字,获取图片的base64和md5

2. pyplot绘图后,获取图片的base64和md5

附1. python2.7 pip安装脚本

python在内存中处理图片
python 2.7

1. 获取gif图片*帧,添加文字,获取图片的base64和md5
import requests
import io

from PIL import ImageFont, ImageDraw, Image, ImageSequence
import numpy as np
import cv2

import base64
import hashlib

req = requests.Session()
response = req.get(picUrl)
if response.status_code == 200:
image_data = response.content
image = io.BytesIO(image_data)
gif = Image.open(image)
# gif图片, 这里只处理一帧
for i, frame in enumerate(ImageSequence.Iterator(gif), 1):
# bytesio
out = io.BytesIO()
frame.save(out, format=”PNG”)
out.seek(0)
file_bytes = np.asarray(bytearray(out.read()), dtype=np.uint8)
bk_img = cv2.imdecode(file_bytes, cv2.IMREAD_COLOR)

# 设置需要显示的字体
font = ImageFont.truetype(“./STSONG.TTF”, 13)

img_pil = Image.fromarray(bk_img)
draw = ImageDraw.Draw(img_pil)

# 图片的指定位置处,添加2组文字
addText_1 = “hello”
addText_2 = “world”
draw.text((90, 30), addText_1.decode(‘utf-8’), font = font, fill = (0, 0, 0))
draw.text((90, 45), addText_2.decode(‘utf-8’), font = font, fill = (0, 0, 0))
del draw

bk_img = np.array(img_pil)
image_data = cv2.imencode(‘.png’,bk_img)[1].tostring()
# base64, md5
image_base64 = base64.b64encode(image_data)
image_md5 = hashlib.md5(image_data).hexdigest()
break
2. pyplot绘图后,获取图片的base64和md5
import matplotlib
matplotlib.use(‘Agg’)
from matplotlib import pyplot as plt
from io import BytesIO
from base64 import b64encode
from hashlib import md5

plt.figure()
plt.plot(x_date, y_data, color=’red’, label=’test_data’)
# plt.show()

figData = BytesIO()
plt.savefig(figData, format=’png’)
figData.seek(0) # rewind to begining of the figData
image_data = figData.read()
# image_data = figData.getvalue()
image_base64 = b64encode(image_data)
image_md5 = md5(image_data).hexdigest()
附1. python2.7 pip安装
wget https://bootstrap.pypa.io/pip/2.7/get-pip.py
python get-pip.py

python图片对比 并标红

python图片对比 并标红

关于Pillow库的详细文档:
https://pillow.readthedocs.io/en/stable/handbook/index.html

代码*终原地址:

How to Create a Diff of an Image in Python

此文章的原作者:
https://blog.csdn.net/weixin_45903952/article/details/104865694?utm_term=%E5%9B%BE%E7%89%87%E5%B7%AE%E5%BC%82%E5%AF%B9%E6%AF%94python&utm_medium=distribute.pc_aggpage_search_result.none-task-blog-2allsobaiduweb~default-3-104865694&spm=3001.4430

代码:

from PIL import Image
from PIL import ImageChops

from screenshot_share import get_image

# get_image(‘http://cq.gov.cn’,’qqq1.png’)

from PIL import Image
from PIL import ImageChops

# from PIL import ImageEnhance

def compare_images(path_one, path_two, diff_save_location):
“””
比较图片,如果有不同则生成展示不同的图片

@参数一: path_one: *张图片的路径
@参数二: path_two: 第二张图片的路径
@参数三: diff_save_location: 不同图的保存路径
“””
image_one = Image.open(path_one)
image_two = Image.open(path_two)
try:
diff = ImageChops.difference(image_one, image_two)
# diff.show() #不同的点图
r, g, b, e = diff.split() # RGB分离
invertr = ImageChops.invert(r) # 红色反向
img1 = invertr.convert(‘1’) # 转成黑白图,黑点即红点

img = img1.convert(“RGBA”) # 转换格式,确保像素包含alpha通道
width, height = img.size # 长度和宽度
for i in range(0, width): # 遍历所有长度的点
for j in range(0, height): # 遍历所有宽度的点
data = img.getpixel((i, j)) # 获取一个像素
if (data.count(255) == 4): # RGBA都是255,改成透明色
img.putpixel((i, j), (255, 255, 255, 0))
else:
# if img.getpixel((i,j))[0]>200:
img.putpixel((i, j), (255, 0, 0, 255))
img.paste((255, 0, 0, 255), (i – 4, j – 4, i, j)) # 放大红点范围
img = img.convert(“RGB”)
image_one_l = image_one.convert(“L”) # 转化为灰度
image_one = image_one_l.convert(“RGB”) # 再把灰度图像转为RGB
# r,g,b=image_one.split()
r, g, b = img.split()
image = Image.composite(image_one, img, g)
image.show()
image.save(“*终_” + diff_save_location)

if diff.getbbox() is None:
# 图片间没有任何不同则直接退出
print(“【+】We are the same!”)
else:
diff.save(diff_save_location)
except ValueError as e:
text = (“表示图片大小和box对应的宽度不一致,参考API说明:Pastes another image into this image.”
“The box argument is either a 2-tuple giving the upper left corner, a 4-tuple defining the left, upper, ”
“right, and lower pixel coordinate, or None (same as (0, 0)). If a 4-tuple is given, the size of the pasted ”
“image must match the size of the region.使用2纬的box避免上述问题”)
print(“【{0}】{1}”.format(e, text))

if __name__ == ‘__main__’:
compare_images(‘img.png’,
‘qqq1.png’,
‘我们不一样.png’)

简单的对比图片差异
代码

im1 = Image.open(‘img.png’)
im2 = Image.open(‘qqq1.png’)
im3 = ImageChops.invert(im2)
Image.blend(im1,im3,0.5).show()

对比之后的图片
%title插图%num

友情链接: SITEMAP | 旋风加速器官网 | 旋风软件中心 | textarea | 黑洞加速器 | jiaohess | 老王加速器 | 烧饼哥加速器 | 小蓝鸟 | tiktok加速器 | 旋风加速度器 | 旋风加速 | quickq加速器 | 飞驰加速器 | 飞鸟加速器 | 狗急加速器 | hammer加速器 | trafficace | 原子加速器 | 葫芦加速器 | 麦旋风 | 油管加速器 | anycastly | INS加速器 | INS加速器免费版 | 免费vqn加速外网 | 旋风加速器 | 快橙加速器 | 啊哈加速器 | 迷雾通 | 优途加速器 | 海外播 | 坚果加速器 | 海外vqn加速 | 蘑菇加速器 | 毛豆加速器 | 接码平台 | 接码S | 西柚加速器 | 快柠檬加速器 | 黑洞加速 | falemon | 快橙加速器 | anycast加速器 | ibaidu | moneytreeblog | 坚果加速器 | 派币加速器 | 飞鸟加速器 | 毛豆APP | PIKPAK | 安卓vqn免费 | 一元机场加速器 | 一元机场 | 老王加速器 | 黑洞加速器 | 白石山 | 小牛加速器 | 黑洞加速 | 迷雾通官网 | 迷雾通 | 迷雾通加速器 | 十大免费加速神器 | 猎豹加速器 | 蚂蚁加速器 | 坚果加速器 | 黑洞加速 | 银河加速器 | 猎豹加速器 | 海鸥加速器 | 芒果加速器 | 小牛加速器 | 极光加速器 | 黑洞加速 | movabletype中文网 | 猎豹加速器官网 | 烧饼哥加速器官网 | 旋风加速器度器 | 哔咔漫画 | PicACG | 雷霆加速