前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >【面试】记某基金管理公司测开面试

【面试】记某基金管理公司测开面试

作者头像
梦无矶小仔
发布于 2023-09-08 09:07:43
发布于 2023-09-08 09:07:43
26200
代码可运行
举报
运行总次数:0
代码可运行

某基金管理公司线下测试开发面试题总结。

预计阅读时间: 25分钟

测开题目如下

可以尝试自己先写,写完之后再去看参考解法哦 ~

1、编写一段代码,把 list 的数平方(语言不限)

ListA = [1, 3, 5, 7, 9, 11]

2、使用 Python 语言编写一个日志装饰器

3、进程、线程、协程有什么区别?

4、请画出 Selenium 框架的工作原理 (Appium 也可以)

5、落地自动化测试项目有哪几个关键节点? 请举例说明

6、请画出 Django 框架请求流程 (也就是,请求的生命周期),如果可以写出函数调用链路是怎样的?(如果未使用过 Django,可以画出你用过的框架)

7、wsgiref 作用是什么?

8、Django 有哪些中间件? 列举 5 个方法,以及中间件的应用场景?

9、请简述 WSGl/uwsgi/uwSGI 三个概念的区别是什么? 为什么有了 uWSGI 还需要 nginx?

10、请列举几种 MySQL 存储引擎,分别有什么优缺点?

11、请画出 Docker C/S 架构图

12、请使用 docker 命令操作

a) 创建一个 volume 名称为 kuma

b) 启动一个容器,名称为 yapi,后台执行,把 host 的 5000 端口映射到容器内 3000端口,并使用上面创建的 volume,挂载到/data/db 目录

解题参考如下

1、编写一段代码,把 list 的数平方(语言不限)

输入:ListA = [1, 3, 5, 7, 9, 11] 输出:[1, 9, 25, 49, 81, 121]

java代码:」

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// 方法一
import java.util.ArrayList;
import java.util.List;

public class SquareList {
    public static void main(String[] args) {
        List<Integer> listA = new ArrayList<Integer>();
        listA.add(1);
        listA.add(3);
        listA.add(5);
        listA.add(7);
        listA.add(9);
        listA.add(11);

        List<Integer> squaredList = new ArrayList<Integer>();
        for (int num : listA) {
            squaredList.add(num * num);
        }

        System.out.println(squaredList);
    }
}

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
// 方法二
import java.util.Arrays;
import java.util.List;
import java.util.stream.Collectors;

public class SquareList {
    public static void main(String[] args) {
        List<Integer> listA = Arrays.asList(1, 3, 5, 7, 9, 11);

        List<Integer> squaredList = listA.stream()
                .map(num -> num * num)
                .collect(Collectors.toList());

        System.out.println(squaredList);
    }
}

通过使用Java 8中引入的Stream API,可以实现更简洁的代码。在上述代码中,我们将listA转换为一个流(stream),然后使用map()操作将每个元素平方,最后通过collect()操作将结果收集到一个新的列表中。这样,我们就得到了平方后的列表并输出结果。

「go代码」

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
package main

import (
 "fmt"
)

func main() {
 listA := []int{1, 3, 5, 7, 9, 11}
 squaredList := make([]int, len(listA))

 for i, num := range listA {
  squaredList[i] = num * num
 }

 fmt.Println(squaredList)
}

「python代码」

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
# 方法一,使用列表推导式
listA = [1, 3, 5, 7, 9, 11]
squared_list = [num**2 for num in listA]
print(squared_list) # [1, 9, 25, 49, 81, 121]

# 方法二,使用map方法
listA = [1, 3, 5, 7, 9, 11]
squared_list = list(map(lambda num: num**2, listA))
print(squared_list)

map()函数接受一个函数和一个可迭代对象作为参数,并将函数应用于可迭代对象中的每个元素

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
#方法三,普通for循环(这应该不是面试官想看到的,但却是最好理解的)
listA = [1, 3, 5, 7, 9, 11]
squared_list = []
for i in listA:
    squared_list.append(i*i) # 写成 i**2 也是可以的
print(squared_list)

**2表示一个数的平方。

2、使用 Python 语言编写一个日志装饰器

方式一:简易版

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
def log_decorator(func):
    def wrapper(*args, **kwargs):
        print("调用函数:", func.__name__)
        print("传入的参数:", args, kwargs)
        result = func(*args, **kwargs)
        print("函数返回结果:", result)
        return result
    return wrapper

@log_decorator
def add(a, b):
    return a + b

result = add(3, 5)
print("最终结果:", result) # 最终结果: 8

方式一:稍微不简易版

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
import logging

logging.basicConfig(level=logging.INFO)

def log_decorator(func):
    def wrapper(*args, **kwargs):
        logger = logging.getLogger()
        logger.info("调用函数: %s", func.__name__)
        logger.info("传入的参数: %s %s", args, kwargs)
        result = func(*args, **kwargs)
        logger.info("函数返回结果: %s", result)
        return result
    return wrapper

@log_decorator
def add(a, b):
    return a + b

result = add(3, 5)
print("最终结果:", result)

代码不做过多解释。

日志可以加入更多的格式,这里参考我之前的文章里面的日志部分:python命令行or控制台or日志带有颜色的输出 (qq.com)

3、进程、线程、协程有什么区别?

进程、线程和协程是计算机中用于实现并发和并行的概念,它们之间有以下区别:

  1. 进程(Process):
    • 进程是操作系统进行资源分配和调度的基本单位。
    • 每个进程有自己独立的地址空间、堆栈和数据段,相互之间不共享内存。
    • 进程之间的通信需要通过进程间通信(IPC)机制,例如管道、信号、消息队列等。
    • 进程之间切换开销较大,资源占用较多。
    • 进程之间是相互独立的,崩溃或异常不会影响其他进程。
  2. 线程(Thread):
    • 线程是在进程内执行的独立执行流。
    • 在同一进程中的线程共享资源,包括内存、文件句柄等。
    • 线程之间切换开销相对较小,资源占用较少。
    • 线程之间通过共享内存进行通信,但需要注意线程同步和互斥问题。
    • 线程的崩溃或异常可能导致整个进程的崩溃。
  3. 协程(Coroutine):
    • 协程是一种用户态的轻量级线程,也称为微线程。
    • 协程的调度由程序员自己控制,可以通过yield/yield from等关键字在执行中保存和恢复上下文。
    • 协程之间切换开销非常小,可以高效地执行异步操作,提高程序的并发性能。
    • 协程适合处理IO密集型任务,但对于计算密集型任务,需要与多线程或多进程配合使用。

「什么场景适合用进程?」

计算密集型的任务(比如:大规模的数据计算和处理)

「什么场景适合用线程?」

IO密集型的任务(比如:文件读写多的,网络请求多的任务)

「什么场景适合用协程?」

IO密集型项目切要求高并发( 比如:用locust 搞压测里面就是用的协程) ,实际上真实项目中对 应高并发的业务并不会选择使用python语言。

总结来说,进程是操作系统资源分配和调度的基本单位,线程是在进程内执行的独立执行流,而协程是一种用户态的轻量级线程。它们在资源占用、切换开销以及通信方式等方面存在不同,应根据具体情况选择合适的并发实现方式。

后面我会专门写几篇进程线程协程的文章。

4、请画出 Selenium 框架的工作原理 (Appium 也可以)

「selenium工作原理」

Selenium工作原理

  • selenium client(python等语言编写的自动化测试脚本)初始化一个service服务,通过Webdriver启动浏览器驱动程序chromedriver.exe
  • 通过RemoteWebDriver向浏览器驱动程序发送HTTP请求,浏览器驱动程序解析请求,打开浏览器,并获得sessionid,如果再次对浏览器操作需携带此id
  • 打开浏览器,绑定特定的端口,把启动后的浏览器作为webdriver的remote server
  • 打开浏览器后,所有的selenium的操作(访问地址,查找元素等)均通过RemoteConnection链接到remote server,然后使用execute方法调用_request方法通过urlib3向remote server发送请求
  • 浏览器通过请求的内容执行对应动作
  • 浏览器再把执行的动作结果通过浏览器驱动程序返回给测试脚本

「Appium工作原理」

appium&selenium工作原理

5、落地自动化测试项目有哪几个关键节点? 请举例说明

这个问题非常宽泛,需要考虑的因素也很多,可以结合自己简历和工作经历进行阐述,以下为关键点参考。

1、从功能测试用例中筛选自动化测试用例

2、调研实践讨论可执行自动化测试用例

3、相关自动化方案的排期,预期,展望

3、选择自动化测试框架或自己搭建相应自动化测试框架

4、自动化脚本编写

5、持续集成与自动化构建

6、定期维护与更新

7、自动化推行(最重要)

6、请画出 Django 框架请求流程 (也就是,请求的生命周期),如果可以写出函数调用链路是怎样的?(如果未使用过 Django,可以画出你用过的框架)

  1. 用户通过浏览器发送请求
  2. 请求到达request中间件,中间件对request请求做预处理或者直接返回response
  3. 若未返回response,会到达urlconf路由,找到对应视图函数
  4. 视图函数做相应预处理或直接返回response
  5. View中的方法可以选择性的通过Models访问底层的数据
  6. 取到相应数据后回到django模板系统,templates通过filter或tags把数据渲染到模板上
  7. 返回response到浏览器展示给客户

7、wsgiref 作用是什么?

wsgiref 是 Python 标准库中的一个模块,提供了一个简单而有效的 WSGI(Web 服务器网关接口)服务器和中间件的实现。主要分为五个模块:simple_server, util, headers, handlers, validate。

wsgiref源码地址:https://pypi.python.org/pypi/wsgiref

8、Django 有哪些中间件? 列举 5 个方法,以及中间件的应用场景?

Django 提供了很多内置的中间件,用于处理请求和响应。以下是 5 个常用的中间件以及它们的应用场景:

  1. SessionMiddleware:处理会话状态的中间件。它通过在请求处理过程中添加一个会话对象来支持会话管理。应用场景包括用户认证、用户状态跟踪功能。
  2. AuthenticationMiddleware:处理用户身份验证的中间件。它负责在每个请求处理过程中检查用户的认证状态,并将用户的认证信息添加到请求对象中。应用场景包括用户登录、权限控制和身份验证。
  3. CsrfViewMiddleware:处理跨站请求伪造(CSRF)保护的中间件。它会自动为每个 POST 请求生成 CSRF 令牌,并在提交表单时验证令牌的有效性。应用场景包括保护表单提交免受 CSRF 攻击。
  4. GZipMiddleware:处理压缩响应的中间件。它在发送响应之前对内容进行 GZip 压缩,从而减小数据传输的大小。应用场景包括提高网站性能和减少带宽消耗。
  5. LocaleMiddleware:处理多语言支持的中间件。它通过根据请求提供的语言首选项来设置适当的语言环境,并将其应用于请求的响应。应用场景包括多语言网站和国际化应用程序。

这些中间件提供了一系列常用的功能和处理程序,可以方便地集成到 Django 应用程序中,简化了开发人员的工作。根据具体的需求,可以根据需要启用和配置这些中间件,以实现不同的功能和处理逻辑。

9、请简述 WSGl/uwsgi/uwSGI 三个概念的区别是什么? 为什么有了 uWSGI 还需要 nginx?

WSGI

WSGI(Web Server Gateway Interface):WSGI 是一种被广泛接受和使用的 Python Web 应用程序与服务器之间的标准接口。它定义了 Web 服务器与 Web 应用程序之间的通信规则,使得服务器能够理解和与应用程序交互。WSGI 规范允许开发人员使用一种统一的方式来编写 Web 应用程序,而不用担心特定服务器的细节。

简言之,是一种描述web服务器(如nginx,uWSGI等服务器)如何与web应用程序(如用Django、Flask框架写的程序)「通信协议」

uwsgi协议

是一个uWSGI服务器自有的协议,是一种「线路协议」而不是通信协议。它用于定义传输信息的类型(type of information),每一个uwsgi packet前4byte为传输信息类型描述,用于与nginx等代理服务器通信,它与WSGI相比是两样东西。

uwSGI

是实现了uwsgi和WSGI两种协议的「Web服务器」

为什么有了 uWSGI 还需要 nginx?

这是因为 Nginx 和 uWSGI 的角色不同。Nginx 主要作为前端服务器、反向代理和负载均衡器,它可以处理静态资源和大量并发连接,将请求转发给后端的 uWSGI 进程处理动态请求。而 uWSGI 则专注于处理 Web 应用程序的请求,它支持 WSGI 协议,负责解析并执行应用程序代码。因此,通过 Nginx 和 uWSGI 的结合,可以提高系统的性能、可靠性和安全性,并实现更好的负载均衡和更高的并发处理能力。

10、请列举几种 MySQL 存储引擎,分别有什么优缺点?

MySQL 提供了多种存储引擎,每个存储引擎都有其独特的特性和适用场景。以下是一些常见的 MySQL 存储引擎以及它们的优缺点:

  1. InnoDB:
    • 优点:支持事务处理和外键约束,提供高并发性能和数据完整性。具备行级锁定和多版本并发控制(MVCC)支持,适用于高并发写入和大量的读写混合场景。
    • 缺点:相对于其他存储引擎,InnoDB 的存储和读取速度相对较慢。因为它支持事务和ACID特性,需要更多的磁盘空间。
  2. MyISAM:
    • 优点:具备较高的读取性能,适合于大量的只读操作和全文搜索。存储和索引数据非常紧凑,占用更少的磁盘空间。
    • 缺点:不支持事务和外键约束。不具备行级锁定,只支持表级锁定,因此在并发写入场景下性能较差。容易发生表损坏,不具备故障恢复能力。
  3. Memory(内存):
    • 优点:数据完全存储在内存中,读取和写入速度非常快。适合于缓存表、临时表和高速度数据捕获等场景。
    • 缺点:只能存储在内存中,断电或重启会导致数据丢失。不支持事务处理,不适合长期存储。
  4. Archive:
    • 优点:适合于归档和历史数据的存储,存储和压缩效率非常高,占用很少的磁盘空间。适合对数据进行稀疏插入和不经常更新的场景。
    • 缺点:不支持索引和事务处理。只能进行追加操作,不适合常规的查询和更新操作。
  5. NDB Cluster:
    • 优点:适用于高可用性和高容量的分布式系统,支持数据分片和自动故障恢复。具备事务处理和ACID特性,适合于高并发读写和实时应用场景。
    • 缺点:相对复杂,需要专门配置和管理,对硬件要求较高。不适合单机和小规模的应用。

这些存储引擎的选择应该根据实际需求和应用场景来决定,权衡每个存储引擎的优缺点,并根据具体场景的读写要求、数据一致性和可用性需求来确定最适合的存储引擎。

11、请画出 Docker C/S 架构图

在 Docker C/S 架构中,有以下几个关键组件:

  1. Docker主机(Docker Host):它是运行 Docker 引擎的物理或虚拟机。Docker 主机负责管理容器的创建、运行和销毁,以及对容器进行资源管理和隔离。
  2. Docker引擎(Docker Engine):它是 Docker 的核心组件,负责接收和处理来自 Docker 客户端的命令,执行容器的创建、运行、停止等操作。Docker 引擎由 Docker 守护进程(Docker Daemon)和 Docker REST API 组成。
  3. Docker客户端(Docker Client):它是与 Docker 引擎进行通信的用户界面,可以使用命令行工具(如docker命令)或图形界面工具来与 Docker 引擎进行交互,通过向 Docker 引擎发送命令来控制容器的创建、运行和管理。
  4. Docker镜像(Docker Image):它是容器的基础,用于创建容器的模板。Docker 镜像包含了一个完整的文件系统,其中包含了运行所需的所有文件和配置。可以通过从 Docker Hub 或私有镜像仓库下载现有的镜像,或者通过 Dockerfile 来构建自己的镜像。
  5. Docker仓库(Docker Registry):它是用于存储和分享 Docker 镜像的中央仓库。Docker Hub 是默认的公共仓库,提供了大量的官方和社区维护的镜像供用户使用。用户也可以部署私有的 Docker 仓库来保存和管理自己的镜像。

12、请使用 docker 命令操作

a) 创建一个 volume 名称为 kuma

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
docker volume create kuma

b) 启动一个容器,名称为 yapi,后台执行,把 host 的 5000 端口映射到容器内 3000端口,并使用上面创建的 volume,挂载到/data/db 目录

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
docker run -d --name yapi -p 5000:3000 -v kuma:/data/db <yapi_image_name>

需要将 <yapi_image_name> 替换为实际的 yapi 镜像名称。

这样就可以使用上述步骤创建的 volume kuma 并挂载到容器内的 /data/db 目录,同时进行端口映射,将 host 的 5000 端口映射到容器内的 3000 端口。容器名称为 yapi,并以后台模式运行。

「本文部分内容参考资料如下:」

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
https://blog.csdn.net/baidu_36943075/article/details/107671011
https://www.cnblogs.com/jiangchunsheng/p/8986532.html
https://www.cnblogs.com/MrYuChen-Blog/p/15571639.html
https://www.cnblogs.com/sunsky303/p/8274586.html
https://blog.csdn.net/weixin_45455015/article/details/100113330

如上文参考解析有不妥之处,欢迎各位小伙伴批评指正!不胜感激!

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2023-08-11,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 梦无矶的测试开发之路 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
Nginx 内嵌GeoIP库
作者:matrix 被围观: 9 次 发布时间:2025-06-05 分类:零零星星 | 无评论 »
HHTjim 部落格
2025/06/06
1140
21.4 Python 使用GeoIP2地图定位
GeoIP2是一种IP地址定位库,它允许开发人员根据IP地址查找有关位置和地理位置的信息。它使用MaxMind公司的IP地址数据库,并提供一个方便的Python API。GeoIP2可以用于许多不同的应用程序,例如网站分析、广告定位和身份验证。GeoIP2提供了许多不同的信息,例如国家、城市、邮政编码、经纬度、时区等等。它还可以使用IPv6地址进行查询。
王 瑞
2023/10/24
8250
21.4 Python 使用GeoIP2地图定位
Python 运用Dpkt库解析数据包
dpkt项目是一个python模块,用于快速、简单的数据包解析,并定义了基本TCP/IP协议,使用该库可以快速解析通过各类抓包工具抓到的数据包,从而提取分析包内的参数。
王 瑞
2022/12/28
2K0
9.Nginx实践之使用MaxMind的GeoIP2实现处理不同国家或城市的访问最佳实践指南
描述: 为了实现根据访问者访问我们的网站时根据其IP显示其所属地,也为获取不同地区访问者的IP地址等相关信息为目的,所以在搜索引擎中查找解决方案,在网络上查询到如下几种方案Nginx+GeoIP2、使用收费 IP 识别接口、DNS 根据地域解析,然后经过多方面考究,最终还是使用Nginx+GeoIP2解决方案。
全栈工程师修炼指南
2022/09/29
6.3K0
9.Nginx实践之使用MaxMind的GeoIP2实现处理不同国家或城市的访问最佳实践指南
[喵咪开源软件推荐(3)]全球IP库-GeoLite2-City
[喵咪开源软件推荐(3)]全球IP库-GeoLite2-City #w-blog博客 哈喽大家好啊!喵咪开源软件推荐(3)终于和大家见面了,这次我们来说说什么呢?大家有没有遇到过这样一个场景,当你出国
喵了个咪233
2018/03/02
5.7K0
[喵咪开源软件推荐(3)]全球IP库-GeoLite2-City
通过GeoIP2分析访问者IP地理位置
MaxMind GeoIP2 服务能识别互联网用户的地点位置与其他特征,应用广泛,包括个性化定制内容、诈欺检测、广告定向、网站流量分析、执行规定、地理目标定位、地理围栏定位 (geo-fencing)以及数字版权管理。目前使用 GeoIP 更多是配合Nginx或Apache服务器进行日志分析获取网站访问量地域分布状况
Tinywan
2019/07/15
2.7K0
Python 开发代码片段笔记
作者编写的一些代码片段,本版本为残废删减版,没有加入多线程,也没有实现任何有价值的功能,只是一个临时记事本,记录下本人编写代码的一些思路,有价值的完整版就不发出来了,自己组织吧,代码没啥技术含量,毕竟Python这一块没怎么认真研究过,代码也都是随性瞎写的,大佬不要喷我,将就着看吧。
王 瑞
2022/12/28
1.2K0
Python 开发代码片段笔记
Tengine编译GeoIP2
nginx geoip geoip2 模块,集成了最新的免费 maxmind geoip mmdb 数据,可以使用nginx去获取访问IP具体归属国家地区,或者根据地区去进行流量分发功能
用户6792968
2022/08/30
8110
Tengine编译GeoIP2
pygeoip通过域名 IP获得地理位置
很多恶意的网络行为,会很明显的在ip位置中凸显出来,比如一个域名,经常访问的大多数人应该位置于中国大陆,可以是最近出现了美国纽约的ip与该域名的文件通信。
Tim在路上
2020/08/04
2.1K0
21.3 Python 使用DPKT分析数据包
dpkt项目是一个Python模块,主要用于对网络数据包进行解析和操作。它可以处理多种协议,例如TCP、UDP、IP等,并提供了一些常用的网络操作功能,例如计算校验和、解析DNS数据包等。由于其简单易用的特性,dpkt被广泛应用于网络安全领域,例如流量分析、漏洞利用、入侵检测等。使用该库可以快速解析通过各类抓包工具抓到的数据包,从而提取分析包内的参数。
王 瑞
2023/10/20
1.2K0
21.3 Python 使用DPKT分析数据包
全网的 IP 归属地显示,带你5分钟加上,就是这么简单!
最近,继新浪微博之后,今日头条、腾讯、抖音、知乎、快手、小红书、百家号等各大平台陆陆续续都上线了"网络用户IP地址显示功能",境外用户显示的是国家,国内的用户显示的省份,而且此项显示无法关闭,归属地强制显示;
一行Java
2022/05/17
2.4K0
全网的 IP 归属地显示,带你5分钟加上,就是这么简单!
python 根据ip获取地理位置
import dpkt import socket import pygeoip import optparse
用户5760343
2019/07/31
1.9K0
Python编写渗透工具学习笔记二 | 0x04编写程序分析流量检测ddos攻击
0x04编写程序分析流量 检测ddos攻击 1使用dpkt发现下载loic的行为 LOIC,即Low Orbit Ion Cannon低轨道离子炮,是用于压力测试的工具,通常被攻击者用来实现DDoS攻击。 我们要编写py脚本来解析http流量,并检查其中有无通过http get获取压缩过的loic二进制可执行文件的情况。为了检查http流量,我们必须先把数据包的以太网部分、ip层以及tcp层部分分解出来,注意http协议是位于tcp协议层之上的。如果http层中使用了get方法,则解析http get所要获
安恒网络空间安全讲武堂
2018/02/06
3.4K0
Python编写渗透工具学习笔记二 | 0x04编写程序分析流量检测ddos攻击
openresty基于lua/geoIp/redis实现ip限制
一、问题背景二、聊一嘴ip库三、解决方案四、下载安装openresty五、验证效果六、geoIp自动更新七、参考
叔牙
2023/02/26
4.6K0
openresty基于lua/geoIp/redis实现ip限制
利用Wireshark与Geolite地址库进行IP定位、地图分布可视化及特征报文深入分析
网络扫描和DDoS攻击等行为频繁出现,对网络安全构成严重威胁。为了更好地应对这些安全挑战,我们需要对网络流量来源分布和行为进行深入分析,从而识别潜在的威胁。本文将介绍如何使用MaxMind地址库(包括GeoLite2 ASN、GeoLite2 City和GeoLite2 Country)结合Wireshark进行IP地理位置信息的解析与分析,以及通过Wireshark内置的26个Geo相关字段如何精准过滤我们想要的特征报文,并让它们呈现在地图分布上。
RokasYang
2024/08/09
1.7K4
利用Wireshark与Geolite地址库进行IP定位、地图分布可视化及特征报文深入分析
小课堂 | 根据ip获取城市名
到目前为止,很多开放接口,如淘宝、新浪、腾讯、百度等开放接口或失效或需要key。很多接口已不再免费调用,本文提供3种方式:
孟君
2021/11/16
4.2K0
小课堂 | 根据ip获取城市名
异步任务实战之远程拉取和风天气API 发布于
在上一篇文章《并发编排与响应式初步》,我们已经对CompletableFuture的功能进行了深入的探讨,并简要介绍了Reactor响应式流相关的概念。然而,要熟练掌握异步任务编排并非一朝一夕之事,尤其是在需要处理 I/O 密集型应用或者一些特殊场景,如:任务间无顺序依赖关系,或者需要在所有任务完成后一次性处理所有返回结果。
DioxideCN
2023/10/21
3340
一文教你识别IP地址所属国家和城市
在网关的应用中,有时会有限制服务在指定的国家和城市进行开放,目前主流的方案有使用付费的在线API和使用离线的IP数据库。接下来将介绍这两种方案的实际应用。
码之有理
2024/05/13
1.5K0
将ip转换为地理位置存入elasticsearch
有些需要将一些数据基于地址位置进行分析,比如哪些区域比较活跃,在什么时间范围内活跃,但是后端仅能获取ip地址,因此需要将ip地址转换为地理位置,幸运的是我们有开源的工具可以使用,maxmind/GeoIP2-java使用GeoLite2-City.mmdb库就可以由ip分析得到对应的经纬度,下面给出具体操作步骤:
johnhuster的分享
2022/03/29
1.1K0
将ip转换为地理位置存入elasticsearch
Grafana展示精美的nginx访问日志图表
获取 Grafana Nginx 图表 链接下载,公众号后台回复 g-nginx-1 下载。
YP小站
2021/03/17
4.4K0
Grafana展示精美的nginx访问日志图表
推荐阅读
相关推荐
Nginx 内嵌GeoIP库
更多 >
LV.6
LYSHARK创始人&CEO
目录
  • 测开题目如下
  • 解题参考如下
  • 1、编写一段代码,把 list 的数平方(语言不限)
  • 2、使用 Python 语言编写一个日志装饰器
  • 3、进程、线程、协程有什么区别?
  • 4、请画出 Selenium 框架的工作原理 (Appium 也可以)
  • 5、落地自动化测试项目有哪几个关键节点? 请举例说明
  • 6、请画出 Django 框架请求流程 (也就是,请求的生命周期),如果可以写出函数调用链路是怎样的?(如果未使用过 Django,可以画出你用过的框架)
  • 7、wsgiref 作用是什么?
  • 8、Django 有哪些中间件? 列举 5 个方法,以及中间件的应用场景?
  • 9、请简述 WSGl/uwsgi/uwSGI 三个概念的区别是什么? 为什么有了 uWSGI 还需要 nginx?
    • WSGI
    • uwsgi协议
    • uwSGI
    • 为什么有了 uWSGI 还需要 nginx?
  • 10、请列举几种 MySQL 存储引擎,分别有什么优缺点?
  • 11、请画出 Docker C/S 架构图
  • 12、请使用 docker 命令操作
    • a) 创建一个 volume 名称为 kuma
    • b) 启动一个容器,名称为 yapi,后台执行,把 host 的 5000 端口映射到容器内 3000端口,并使用上面创建的 volume,挂载到/data/db 目录
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档