iOS发送探针日志到日志系统的简单实现
通过参考Testin的SDK实现方式,我们大致可以确定他们背后的实现方式:
首先,通过加载Testin的SDK,然后收集各种七七八八的数据,再通过socket发送数据到云端。
云端我们已经有了,就是http://log.qa.huayu.nd:8088
但是如何从iOS收集数据呢,我们需要自己写SDK,SDK的实现一般是采用framework来打包,但是这里简单为主,我将使用静态库来实现,我这里实现的是libHyLog01.a
要编写这样的库,你需要一台Mac,需要xcode开发环境
使用xcode新建一个静态库项目
新建一个类:
MyClass
然后,开始写探针日志发送代码:
- //
- // MyClass.m
- // HyLog01
- //
- // Created by 林 志宏 on 15-6-10.
- // Copyright 2015年 网龙公司. All rights reserved.
- //
- #import "MyClass.h"
- #import <arpa/inet.h>
- #import <errno.h>
- #import <netdb.h>
- #import <netinet/in.h>
- #import <stdbool.h>
- #import <stdio.h>
- #import <stdlib.h>
- #import <string.h>
- #import <sys/socket.h>
- #import <sys/types.h>
- #import <unistd.h>
- static const in_port_t kPortNumber = 11215;
- @implementation MyClass
- -(void) getConn
- {
- const char* hostname = "log.qa.huayu.nd";
- struct sockaddr_storage* server_addr_ptr;
- struct sockaddr_in* sock_addr_ptr;
- struct sockaddr_storage server_addr;
- struct hostent *host = NULL;
- host = gethostbyname2(hostname, AF_INET);
- server_addr_ptr = &server_addr;
- server_addr.ss_family = host->h_addrtype;
- sock_addr_ptr = (struct sockaddr_in*)server_addr_ptr;
- sock_addr_ptr->sin_len = sizeof(*sock_addr_ptr);
- sock_addr_ptr->sin_port = htons(kPortNumber);
- sock_addr_ptr->sin_addr = *(struct in_addr*)host->h_addr_list[0];
- memset(&sock_addr_ptr->sin_zero, 0, sizeof(sock_addr_ptr->sin_zero));
- int sockfd;
- sockfd = socket(server_addr.ss_family, SOCK_STREAM, 0);
- int err = connect(sockfd, (struct sockaddr *)&server_addr, server_addr.ss_len);
- const char *bytes = "9996:hello, ios\n";
- char buffer[30];
- int i;
- for (i = 0; i < 15; i++) {
- buffer[i] = bytes[i];
- }
- buffer[i] = '\0';
- write(sockfd, buffer, 15);
- close(sockfd);
- NSLog(@"conn: %d %d", err, (int)sizeof(buffer));
- // memset(&sock_addr_ptr-
- NSLog(@"hello");
- NSLog(@"send log to huayu");
- }
- @end
然后,开始编译
接下来,就是在我们的实际项目中进行引用了
我创建了一个View_Switcher项目来引用我刚刚开发的库
运行:
然后,我们可以看到我们的日志系统服务端收到了数据了:
http://log.qa.huayu.nd:8088/
参考文献:
http://blog.sina.com.cn/s/blog_7b9d64af0101jlym.html
iOS发送探针日志到日志系统的简单实现的更多相关文章
- iOS各框架功能简述以及系统层次结构简单分析
iOS各个框架所对应的功能简单介绍 iOS系统结构层次:
- Es+kafka搭建日志存储查询系统(设计)
现在使用的比较常用的日志分析系统有Splunk和Elk,Splunk功能齐全,处理能力强,但是是商用项目,而且收费高.Elk则是Splunk项目的一个开源实现,Elk是ElasticSearch(Es ...
- iOS 中捕获程序崩溃日志
iOS 中捕获程序崩溃日志 (2014-04-22 17:35:59) 转载▼ iOS开发中遇到程序崩溃是很正常的事情,如何在程序崩溃时捕获到异常信息并通知开发者,是大多数软件都选择的方法.下 ...
- 海量日志实时收集系统架构设计与go语言实现
日志收集系统应该说是到达一定规模的公司的标配了,一个能满足业务需求.运维成本低.稳定的日志收集系统对于运维的同学和日志使用方的同学都是非常nice的.然而这时理想中的日志收集系统,现实往往不是这样的. ...
- 企业日志大数据分析系统ELK+KAFKA实现【转】
背景: 最近线上上了ELK,但是只用了一台Redis在中间作为消息队列,以减轻前端es集群的压力,Redis的集群解决方案暂时没有接触过,并且Redis作为消息队列并不是它的强项:所以最近将Redis ...
- 用ELK搭建简单的日志收集分析系统【转】
缘起 在微服务开发过程中,一般都会利用多台服务器做分布式部署,如何能够把分散在各个服务器中的日志归集起来做分析处理,是一个微服务服务需要考虑的一个因素. 搭建一个日志系统 搭建一个日志系统需要考虑一下 ...
- Linux下日志文件监控系统Logwatch的使用记录
Linux下日志文件监控系统Logwatch的使用记录 原文:http://www.cnblogs.com/kevingrace/p/6519504.html 在维护Linux服务器时,经常需要查看系 ...
- centos7安装Logwatch配合msmtp邮件客户端发送服务器监控分析日志
########################### #DATE 2016-07-29 # #Authur by Denilas Yeung ...
- Kubernetes-20:日志聚合分析系统—Loki的搭建与使用
日志聚合分析系统--Loki 什么是Loki? Loki 是 Grafana Labs 团队最新的开源项目,是一个水平可扩展,高可用性,多租户的日志聚合系统.它的设计非常经济高效且易于操作,因为它不会 ...
- Cisco配置发送日志到日志服务器
Cisco配置发送日志到日志服务器logging 172.16.6.22logging onlogging trap 7 //指定日志消息的级别 (0:紧急(Emergencies) 1:告警(Al ...
随机推荐
- 《最新出炉》系列初窥篇-Python+Playwright自动化测试-1-环境准备与搭建
1.简介 有很多人私信留言宏哥问能不能介绍一下Playwright这款自动化神器的相关知识,现在网上的资料太少了.其实在各大博客和公众号也看到过其相关的介绍和讲解.要不就是不全面.不系统,要不就是系统 ...
- 驱动开发:内核LoadLibrary实现DLL注入
远程线程注入是最常用的一种注入技术,在应用层注入是通过CreateRemoteThread这个函数实现的,该函数通过创建线程并调用 LoadLibrary 动态载入指定的DLL来实现注入,而在内核层同 ...
- .NET周报 【6月第2期 2023-06-11】
国内文章 如何计算一个实例占用多少内存? https://www.cnblogs.com/artech/p/size-calculation.html 我们都知道CPU和内存是程序最为重要的两类指标, ...
- CKS 考试题整理 (09)-日志审计 log audit
Task 在cluster中启用审计日志.为此,请启用日志后端,并确保: 日志存储在 /var/log/kubernetes/audit-logs.txt 日志文件能保留 10 天 最多保留 2 个旧 ...
- 【webpack系列】从基础配置到掌握进阶用法
前言 本篇文章将介绍一些webpack的进阶用法,演示内容继承自上一篇文章的内容,所以没看过上一篇文章的建议先学习上一篇内容再阅读此篇内容,会更有利于此篇的学习- 文件指纹 文件指纹指的是打包输出的文 ...
- 记一次etcd全局锁使用不当导致的事故
1.背景介绍 前两天,现场的同事使用开发的程序测试时,发现日志中报etcdserver: mvcc: database space exceeded,导致 etcd 无法连接.很奇怪,我们开发的程序只 ...
- MODBUS-TCP转Ethernet IP 网关连接空压机配置案例
本案例是工业现场应用捷米特JM-EIP-TCP的Ethernet/IP转Modbus-TCP网关连接欧姆龙PLC与空压机的配置案例.使用设备:欧姆龙PLC,捷米特JM-EIP-TCP网关, ETHER ...
- 4.4 x64dbg 绕过反调试保护机制
在Windows平台下,应用程序为了保护自己不被调试器调试会通过各种方法限制进程调试自身,通常此类反调试技术会限制我们对其进行软件逆向与漏洞分析,下面是一些常见的反调试保护方法: IsDebugger ...
- Tomcat启动时出现乱码的解决方式
在网上下载了一个版本号为apache-tomcat-8.5.38的Tomcat,因为这个Tomcat一直没有用过,所以今天启动时出现了如下乱码: 解决方案: 找到Tomcat目录下conf文件夹中的l ...
- P3574 [POI2014] FAR-FarmCraft 吐槽 + 题解
洛谷上面的题解写的真的不太好,有很多错误,我来谈谈自己的理解. 设 \(f[i]\) 表示以 \(i\) 为根节点的子树中(包括节点 \(i\))的所有人安装好游戏所需要的时间(与下面的 \(g[i] ...