9.3作业

#include <myhead.h>
#define SERPORT 8888
#define SERIP "192.168.0.178"
int main(int argc, const char *argv[])
{
	int oldfd = socket(AF_INET,SOCK_DGRAM,0);
	if(oldfd==-1)
	{
		perror("socket");
		return -1;
	}

	struct sockaddr_in sin = {
		.sin_family = AF_INET,
		.sin_port = htons(SERPORT),
		.sin_addr.s_addr = inet_addr(SERIP)
	};

	if(bind(oldfd,(struct sockaddr *)&sin,sizeof(sin))==-1)
	{
		perror("bind");
		return -1;
	}
	struct sockaddr_in cin;
	socklen_t cinlen = sizeof(cin);
	char buff[1024];
	while(1)
	{
		memset(buff, 0, sizeof(buff));
		int len = recvfrom(oldfd, buff, sizeof(buff), 0, (struct sockaddr *)&cin, &cinlen);
		if(len == -1)
		{
			perror("recvfrom");
			continue;
		}
		printf("服务器接收到的消息:%s\n", buff);

		// 使用connect函数连接到客户端
		if(connect(oldfd, (struct sockaddr *)&cin, cinlen) == -1)
		{
			perror("connect");
			continue;
		}
		printf("与客户端 %s:%d 建立连接\n", inet_ntoa(cin.sin_addr), ntohs(cin.sin_port));

		// 使用send函数发送响应
		strcat(buff, " - 服务器已收到");
		if(send(oldfd, buff, strlen(buff), 0) == -1)
		{
			perror("send");
			break;
		}
		while(1)
		{
			memset(buff,0,sizeof(buff));
			int len = recvfrom(oldfd,buff,sizeof(buff),0,(struct sockaddr *)&cin, &cinlen);
			if(len == 0)
			{
				perror("error");
				break;
			}
			printf("服务器接收到的消息:%s\n",buff);
		}
		close(oldfd);
		return 0;
	}
}

### Kettle 9.3 版本使用教程 #### 启动与初步设置 为了启动 Kettle 并进行初次配置,需确认 JDK 已经正确安装[^3]。Kettle 是基于 Java 的应用程序,因此 Java 环境对于运行至关重要。 ```bash java -version ``` 上述命令用于验证当前 Linux 系统上的 Java 版本是否满足 Kettle 运行需求。 #### 创建首个转换项目 打开 Spoon(Kettle GUI),创建新转换: 1. **新建转换** - 菜单栏选择 `File` -> `New` -> `Transformation`. 2. **定义数据源** - 利用左侧的 “Design” 面板拖拽组件到工作区。 - 对于 ClickHouse 数据库连接,可选用 `Table Input` 或者 `Database Lookup` 组件,并在弹出窗口内填写必要的 JDBC URL 和认证信息以完成数据库链接配置[^1]. 3. **设计数据流路径** 设计阶段涉及构建从输入至输出的数据处理流程。此过程可能包括但不限于清洗、过滤、聚合等操作。每一步骤均通过特定图标表示,在属性面板调整各步骤参数实现定制化逻辑。 4. **保存并测试转换** - 将工程文件存储为 `.ktr` 文件格式以便后续调用或修改。 - 执行前建议先做预览 (`Preview`) 来检验预期效果;正式执行则点击工具条中的播放按钮(`Run`)。 #### 构建作业(Job) 除了单一转换外,更复杂的业务场景往往需要组合多个转换形成完整的 ETL 流程—即所谓的 "作业". - 新建作业同理可通过菜单选项 `File` -> `New` -> `Job` 实现; - 添加先前制作好的转换作为子任务,利用箭头指示前后依赖关系; - 设置控制结构如条件分支、循环迭代等增强灵活性和自动化程度。 #### 日常维护与优化 随着应用深入,定期审视现有架构性能瓶颈成为必要环节: - 关注日志记录水平设定,适当降低冗余度提高效率; - 探索社区资源获取最佳实践案例分享和技术支持; - 不断更新插件生态保持软件活力。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值