一步一步以安装包的方式,搭建API测试工具Hitchhiker

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,高可用系列 2核4GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 首先要感谢Hitchhiker的作者BrookShi(https://github.com/brookshi/Hitchhiker)!感谢他分享这个非常棒的API测试平台。Hitchhiker 是一个基于Nodejs的跨平台Web程序,你可以部署到 Linux, Mac or Windows。

首先要感谢Hitchhiker的作者BrookShi(https://github.com/brookshi/Hitchhiker)!感谢他分享这个非常棒的API测试平台。Hitchhiker 是一个基于Nodejs的跨平台Web程序,你可以部署到 Linux, Mac or Windows。Hitchhiker 在Docker Hub上也有镜像可以使用,所以推荐的方式还是用Docker来部署,不论是首次还是以后升级都会更容易。

由于笔者不熟悉Docker的使用,采用的是安装包方式部署。由于Hitchhiker依赖的软件较多,部署过程中遇到一些弯路,这个文档也是一边探索一边写成的。搭建时还是1月底,基于Hitchhiker v0.8,现在已经更新到0.9。最近忙于研究Python自动化方面的工作,没有把搭建文档发布到博客园。

 

首先是准备工作:

  1. 安装Development Tools
  2. 安装(更新)Python3
  3. 安装Node
  4. 更新C++
  5. 安装MySQL Server

 

最后是我们的主角Hitchhiker:

这部分的搭建步骤,请参阅在线文档:http://doc.hitchhiker-api.com/cn/installation/StepByStep.html

 

1. 更新系统:

我的系统是CentOS 7.3。

# yum update -y
# yum group install -y "Development Tools"

 

2. 升级Python到Python3

Nodejs需要,请安装python前,先安装此模块。

# yum install -y bzip2*

安装依赖组件:

# yum install -y zlib zlib-devel
# yum install -y gcc gcc-c++ kernel-devel

下载Python的压缩包,并解压:

# wget https://www.python.org/ftp/python/3.6.4/Python-3.6.4.tar.xz
# xz -d Python-3.6.4.tar.xz
# tar xvf Python-3.6.4.tar
# cd Python-3.6.4

创建安装文件夹,并开始编译:

# mkdir /usr/local/python3
# ./configure --prefix=/usr/local/python3 --enable-optimizations
# make && make install

添加到环境变量:

export PATH=$PATH:/usr/local/python3/bin

确认安装完成:

# which python
# python -V

替换系统中原有的python2:

/usr/bin目录中有python, python2.7, python2三个文件,其实都是指向python2.7的,这里将python(软连接文件)删除。

# cd /usr/bin
# rm -f python

重新创建python的软连接文件,指向python3.6:

# ln -s /usr/local/python3/bin/python3.6 /usr/bin/python
# python -V

检查python的版本是否被正确替换掉了。

 

收尾替换工作:

原则:所有python相关的应用,如果为使用/usr/bin/python开头的脚本统统替换掉,如果其只能在python2.7下执行,则替换为python2.7。比如,不替换的话,yum命令将无法执行。

根据网路上的信息,相关的文件可能有如下, 具体情况视具体情况而定:

   - /usr/bin/yum

   - /usr/libexec/urlgrabber-ext-down

很容易,编辑/usr/bin/yum,在第一行的末尾增加一个2就好了。

修改前:#! /usr/bin/python

修改后:#! /usr/bin/python2

 

3. 安装NodeJS

首先从官网下载NodeJS源码:

http://nodejs.org/

命令:wget http://nodejs.org/dist/<版本号>/node-<版本号>.tar.gz

# wget https://nodejs.org/dist/v8.9.4/node-v8.9.4.tar.gz

安装nodejs所要依赖的包

安装gcc:

# yum install -y gcc gcc-c++

安装libssl-dev:

# yum install -y openssl-devel

解压NodeJS源码文件:

# tar zxvf node-v8.9.4.tar.gz
# cd node-v8.9.4

配置Node安装目录:

# mkdir -p /usr/local/node
# ./configure --prefix=/usr/local/node

此时可能会提示C++版本太旧,需要更新:

WARNING: C++ compiler too old, need g++ 4.9.4 or clang++ 3.4.2 (CXX=g++)

如果出现C++版本太旧的提示内容,中断Node的安装,转到下一段落,更新C++的部分。

 

4. 更新C++

从Node的目录中退出来,下载gcc源码压缩包。

到下面的网站上查找gcc源码:

http://gcc.skazkaforyou.com/releases/

# wget http://gcc.skazkaforyou.com/releases/gcc-4.9.4/gcc-4.9.4.tar.gz

如果下载很慢,可能需要扶梯。

下载完成后,解压缩:

# tar zxvf gcc-4.9.4.tar.gz
# cd gcc-4.9.4

运行download_prerequisites脚本,这个脚本会自动帮你下载所需要的依赖文件和库:

# ./contrib/download_prerequisites

等下载完成后,继续执行后续命令。

创建输出目录:

# mkdir gcc-build-4.9.4
# cd gcc-build-4.9.4
# ../configure --enable-checking=release --enable-languages=c,c++ --disable-multilib

生成make文件:

# make

编译过程非常久,大概需要一个小时。

安装gcc:

# make install

完成后,需要用新的动态库文件,代替系统原有的旧版本:

查找编译gcc时生成的最新动态库:

# find / -name "libstdc++.so*"

 如上图所示,/usr/lib64目录下,没有新版本的libstdc++.so.6.0.20。

将找到的动态库libstdc++.so.6.0.20复制到/usr/lib64目录:

# cp /root/downloads/gcc-4.9.4/gcc-build-4.9.4/stage1-x86_64-unknown-linux-gnu/libstdc++-v3/src/.libs/libstdc++.so.6.0.20 /usr/lib64/

切换工作目录至/usr/lib64;由于libstdc++.so.6对应的是旧版本文件,删除原来的软连接:

# cd /usr/lib64
# ll libstdc++.so.6*

# rm -rf libstdc++.so.6

 将默认库的软连接指向最新动态库:

# ln -s libstdc++.so.6.0.20 libstdc++.so.6
 

 更新C++的工作完成后,继续Node的安装。

 

 回到node的源代码目录,继续编译并安装Node的源码:

# ./configure --prefix=/usr/local/node
# make && make install

验证安装是否成功:

# node -v
如果看到以下错误提示:
  
原因是,在/usr/local/bin目录中没有node可执行文件,需要手工添加到环境变量。
export PATH=$PATH:/usr/local/node/bin
  

 

5. 安装MySQL

安装前,先删除系统预装的MariaDB。

- 因为CentOS的默认数据库已经不再是MySQL了,而是MariaDB,为什么呢?

MariaDB数据库管理系统是MySQL的一个分支,主要由开源社区在维护,采用GPL授权许可。开发这个分支的原因之一是:甲骨文公司收购了MySQL后,有将MySQL闭源的潜在风险,因此社区采用分支的方式来避开这个风险。MariaDB的目的是完全兼容MySQL,包括API和命令行,使之能轻松成为MySQL的代替品。 

查看当前安装的mariadb包:
# rpm -qa | grep mariadb

卸载mariadb:
# rpm -e --nodeps mariadb-libs-5.5.56-2.el7.x86_64

Mysql数据库安装过程如下:

下载mysql的repo源(CentOS 7.2的yum源中默认没有mysql,要先下载mysql的repo源):

# wget http://repo.mysql.com/mysql57-community-release-el7.rpm
安装mysql57-community-release-el7.rpm包:
# rpm -ivh mysql57-community-release-el7.rpm --nodeps --force

安装这个包后,会获得两个mysql的yum repo源:
# ls -l /etc/yum.repos.d/mysql-community*

确认存在下列两个repo源文件:

 - mysql-community.repo
 - mysql-community-source.repo 

安装mysql:

# yum install -y mysql-server

启用mysql服务:

# systemctl enable mysqld
# systemctl start mysqld

查看MySQL服务是否已启动:
# systemctl status mysqld

重置root密码:

MySQL5.7会在安装后为root用户生成一个随机密码,而不是像以往版本的空密码。可以安全模式修改root登录密码或者用随机密码登录修改密码。

MySQL为root用户生成的随机密码通过mysqld.log文件可以查找到:

# grep 'temporary password' /var/log/mysqld.log
  

  # mysql -u root -p

  mysql> Enter password: (输入刚才查询到的随机密码, NjAh84pp,(-g

 修改root用户密码:(MySQL的密码策略比较复杂,过于简单的密码会被拒绝)。首先修改安全策略,避免过于简单的密码被拒绝:

mysql> set global validate_password_policy=0;
mysql> set global validate_password_length=4;

 重置用户密码,完成后,保存退出::

mysql> alter user 'root'@'localhost' identified by 'root-1234';

mysql> flush privileges;
mysql> quit;

 使用刚刚设置的新密码登录:

# mysql -u root -p

如果进行操作出现下面的提示:
You must reset your password using ALTER USER statement before executing this statement.

就再设置一遍密码:
mysql> set password = password('root-1234');

开放3306端口:

允许使用用户名root密码root-1234从任何主机连接到mysql服务器。

mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'root-1234' WITH GRANT OPTION;

mysql> FLUSH PRIVILEGES;

 

以上是Hitchhiker所有依赖的组建安装,后面的步骤请阅读官方手册。

这里说一下,如果运行node setup.js时,看到错误提示:

/bin/sh: pm2: command not found

这是由于pm2没有安装,解决方法如下:

# npm install pm2 -g

  # whereis pm2
  创建pm2的软连接文件
  # ls -n /usr/local/node/bin/pm2 /usr/bin/pm2

然后再次执行node setup.js,就可以打开Hitchhiker的设置页面了。

 

另外,BrookShi已经在最新的文档中注明了,如果是升级,记得保留pm2.json,这里有你所有的配置,如果覆盖了需要重新设置!

升级时,可以拷贝build/pm2.json文件到别处、 移动旧版本Hitchhiker文件夹到备份目录。然后,解压Hitchhiker最新版的zip文件到原路径,再用之前的pm2.json文件覆盖同名文件就好了。

 

关于Hitchhiker的启动,可以写一个小脚本,runAPP.sh:

# vim runApp.sh
pm2 start ./pm2.json &

# chmod +x runApp.sh

 

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
3月前
|
数据可视化 测试技术 API
JMeter、Apipost 与 Postman 的 API 测试对比:为什么 APIPost 是更聪明的选择
API测试如同筹备一场晚宴,选对工具至关重要。JMeter功能强大但上手难,适合专业用户;Postman简单易用,但在复杂场景和团队协作中表现有限;而Apipost则是一款智能高效的“厨房神器”。它性能测试轻松、结果清晰、学习门槛低,并且能一键集成CI/CD流程。对于追求效率与便捷的团队而言,Apipost无疑是更优选择,让API测试如同五星大厨烹饪般丝滑流畅。
|
3月前
|
监控 测试技术 数据库连接
RunnerGo API 性能测试实战:从问题到解决的全链路剖析
API性能测试是保障软件系统稳定性与用户体验的关键环节。本文详细探讨了使用RunnerGo全栈测试平台进行API性能测试的全流程,涵盖测试计划创建、场景设计、执行分析及优化改进。通过电商平台促销活动的实际案例,展示了如何设置测试目标、选择压测模式并分析结果。针对发现的性能瓶颈,提出了代码优化、数据库调优、服务器资源配置和缓存策略等解决方案。最终,系统性能显著提升,满足高并发需求。持续关注与优化API性能,对系统稳定运行至关重要。
|
3月前
|
监控 测试技术 数据库连接
利用 RunnerGo 深度探索 API 性能测试:从理论到实践
API性能测试是保障应用稳定性和用户体验的关键环节。本文详细探讨了如何使用RunnerGo全栈测试平台进行高效API性能测试,涵盖测试计划创建、场景设计、参数配置到执行与分析全过程。通过电商平台促销活动案例,展示了高并发下的测试策略与优化措施,如代码与数据库查询优化、数据库连接池扩容、服务器资源配置调整及缓存策略实施等。最终显著提升系统性能,满足高并发需求。API性能测试需持续关注与优化,以适应业务发展和用户需求变化。
136 33
|
3月前
|
监控 安全 测试技术
选择Postman免费版还是付费版,进行 API 测试呢?
深入了解 Postman 免费版和付费版的细节,看看哪一个更适合您的 API 需求。
|
3月前
|
存储 前端开发 数据可视化
Postman vs. Apifox 用于 API 测试全面对比
寻找一款可靠的 API 测试工具?这份对比分析将深入探讨 Postman 和 Apifox 的功能和特性。了解哪款工具最适合您的 API 测试需求。
|
3月前
|
jenkins 测试技术 Shell
利用Apipost轻松实现用户充值系统的API自动化测试
API在现代软件开发中扮演着连接不同系统与模块的关键角色,其测试的重要性日益凸显。传统API测试面临效率低、覆盖率不足及难以融入自动化工作流等问题。Apipost提供了一站式API自动化测试解决方案,支持零代码拖拽编排、全场景覆盖,并可无缝集成CI/CD流程。通过可视化界面,研发与测试人员可基于同一数据源协作,大幅提升效率。同时,Apipost支持动态数据提取、性能压测等功能,满足复杂测试需求。文档还以用户充值系统为例,详细介绍了从创建测试用例到生成报告的全流程,帮助用户快速上手并提升测试质量。
|
4月前
|
缓存 监控 负载均衡
如何提升 API 性能:来自 Java 和测试开发者的优化建议
本文探讨了如何优化API响应时间,提升用户体验。通过缓存(如Redis/Memcached)、减少数据负载(REST过滤字段或GraphQL精确请求)、负载均衡(Nginx/AWS等工具)、数据压缩(Gzip/Brotli)、限流节流、监控性能(Apipost/New Relic等工具)、升级基础设施、减少第三方依赖、优化数据库查询及采用异步处理等方式,可显著提高API速度。快速响应的API不仅让用户满意,还能增强应用整体性能。
|
4月前
|
监控 安全 测试技术
避免15个常见的API测试错误
API测试是现代软件开发中的关键环节,但测试人员常陷入15个常见错误,如忽略文档、遗漏错误响应、缺乏自动化等。这些问题可能导致API的可靠性、安全性及性能下降。本文详细解析这些错误并提供解决建议。Apipost作为全方位工具,支持自动化测试、动态数据处理与安全性验证,助力高效测试,确保API在各种场景下稳定运行。通过避免这些陷阱,团队可显著提升API质量。
|
4月前
|
人工智能 测试技术 API
Windows用户必备:Postman v11详细安装指南与API测试入门教程(附官网下载
Postman是全球领先的API开发与测试工具,支持REST、SOAP、GraphQL等协议调试。2025年最新版v11新增AI智能生成测试用例、多环境变量同步等功能,适用于前后端分离开发、自动化测试、接口文档自动生成及团队协作共享API资源。本文详细介绍Postman的软件定位、核心功能、安装步骤、首次配置、基础使用及常见问题解答,帮助用户快速上手并高效利用该工具进行API开发与测试。
|
4月前
|
数据可视化 JavaScript 前端开发
利用Postman和Apipost进行API测试的实践与优化-动态参数
在API测试中,Postman和Apipost是常用的工具。Postman内置变量功能有限,面对复杂场景时需编写JavaScript脚本,增加了维护成本。而Apipost提供丰富的内置变量、可视化动态值配置和低代码操作,支持生成真实随机数据,如邮箱、手机号等,显著提升测试效率和灵活性。对于复杂测试场景,Apipost是更好的选择,能有效降低开发与维护成本,提高测试工作的便捷性和可维护性。