【web server】项目中的一些小点

简介: 【web server】项目中的一些小点

本篇记录项目中的一些小点,比如支持读取配置文件,命令行读取参数等。

读取配置文件

程序运行中用到的一些参数,首先会读取配置文件中的配置,若在程序运行时指定了参数,按指定的参数运行,首先来看读取配置文件:

配置文件是server.conf文件,配置项按照key:value的方式书写,比如:

PORT:8080
THREADNUM:8

端口号为8080,线程数为8。

来看一下读取配置文件的类Config中的关键代码:

void Config::readConfigFile()
{
    char *pLine = nullptr;
    size_t len = 0;
    ssize_t nread;
    while ((nread = getline(&pLine, &len, m_pFp)) != -1) {
        //移除多余的空格等符号
        char *p = strchr(pLine, ':');
        if (p == nullptr) return;
        char *pValue = removeSpace(p, strlen(p));
        char *pKey = removeSpace(pLine, strlen(pLine) - strlen(p) - 1);
        printf("%s, %s", pKey, pValue);
        m_mapKeyValue.insert(std::make_pair(pKey, pValue));
    }
}

按行读取配置文件,以:分割键值,去除两边多余的空格,保存到一个map成员变量m_mapKeyValue中,这样获取配置的时候直接从内存中取即可,不用重复读取文件。

命令行参数

程序支持命令行读取参数,比如

./server -d -p 8080  //-d表示以守护进程方式运行,-p表示执行端口号

主要是通过getopt调用:

int opt = 0;
    while ((opt = getopt(argc, argv, "dp:")) != -1) {
        switch (opt) {
            case 'd':
                //守护进程
                {
                    pid_t pid;
                    if (fork() < 0) {
                        perror("fork()");
                    } else if (fork() > 0) {
                        exit(0);
                    }
                    //子进程
                    setsid();
                    close(1);
                }
                break;
            case 'p':
                //端口号
                iPort = atoi(optarg);
                break;
            default:
                fprintf(stderr, "Usage: %s [-d] [-p port]\n", argv[0]);
                exit(-1);
        }
    }

调试宏

在调试程序时,除了可以查看日志的输出,还可以定义一个这样的宏:

#ifdef DEBUG 
#define DBG(format, args...) {\
  printf(format, ##args);\
}
#else
#define DBG(format, ...)
#endif

当我们需要输出Debug信息时,在gcc编译时通过-D选项定义一个DEBUG宏即可。比如:

gcc test.cpp -DDEBUG

这样运行后便可以看到一些输出信息,方便调试。

构建脚本

项目采用cmake构建,执行cmake后往往还需要执行make构建,因此我们可以将这些操作放在一个脚本中做,比如build.sh

#!/bin/bash
mkdir build
cd build
cmake ../
make

这样执行一个build.sh即可。

日志文件输出

server运行产生的日志文件,以当前日期命名(比如2022_05_13_log),并输出在当前目录:

char log_full_name[256] = {0};
getcwd(log_full_name, 256);
snprintf(log_full_name, 255, "%s%d_%02d_%02d_%s", log_full_name, my_tm.tm_year + 1900, my_tm.tm_mon +1, my_tm.tm_mday, FILE_TAIL);

还有一个小技巧,在运行server时实时查看日志文件。可以通过tail -f 2022_05_13_log查看日志文件,有日志写入时都能实时看到。

相关实践学习
【涂鸦即艺术】基于云应用开发平台CAP部署AI实时生图绘板
【涂鸦即艺术】基于云应用开发平台CAP部署AI实时生图绘板
相关文章
|
9月前
|
安全 Java API
Java Web 在线商城项目最新技术实操指南帮助开发者高效完成商城项目开发
本项目基于Spring Boot 3.2与Vue 3构建现代化在线商城,涵盖技术选型、核心功能实现、安全控制与容器化部署,助开发者掌握最新Java Web全栈开发实践。
786 1
|
10月前
|
JavaScript Java 微服务
现代化 Java Web 在线商城项目技术方案与实战开发流程及核心功能实现详解
本项目基于Spring Boot 3与Vue 3构建现代化在线商城系统,采用微服务架构,整合Spring Cloud、Redis、MySQL等技术,涵盖用户认证、商品管理、购物车功能,并支持Docker容器化部署与Kubernetes编排。提供完整CI/CD流程,助力高效开发与扩展。
1066 64
|
11月前
|
前端开发 Java API
Spring Cloud Gateway Server Web MVC报错“Unsupported transfer encoding: chunked”解决
本文解析了Spring Cloud Gateway中出现“Unsupported transfer encoding: chunked”错误的原因,指出该问题源于Feign依赖的HTTP客户端与服务端的`chunked`传输编码不兼容,并提供了具体的解决方案。通过规范Feign客户端接口的返回类型,可有效避免该异常,提升系统兼容性与稳定性。
750 0
|
11月前
|
安全 JavaScript Java
java Web 项目完整案例实操指南包含从搭建到部署的详细步骤及热门长尾关键词解析的实操指南
本项目为一个完整的JavaWeb应用案例,采用Spring Boot 3、Vue 3、MySQL、Redis等最新技术栈,涵盖前后端分离架构设计、RESTful API开发、JWT安全认证、Docker容器化部署等内容,适合掌握企业级Web项目全流程开发与部署。
942 0
|
人工智能 安全 程序员
用 Colab 和 ngrok 免费部署你的 Web UI 项目,随时随地访问!
用 Colab 和 ngrok 免费部署你的 Web UI 项目,随时随地访问!
1522 12
|
监控 安全 测试技术
如何在实际项目中应用Python Web开发的安全测试知识?
如何在实际项目中应用Python Web开发的安全测试知识?
284 61
|
网络协议 Java Shell
java spring 项目若依框架启动失败,启动不了服务提示端口8080占用escription: Web server failed to start. Port 8080 was already in use. Action: Identify and stop the process that’s listening on port 8080 or configure this application to listen on another port-优雅草卓伊凡解决方案
java spring 项目若依框架启动失败,启动不了服务提示端口8080占用escription: Web server failed to start. Port 8080 was already in use. Action: Identify and stop the process that’s listening on port 8080 or configure this application to listen on another port-优雅草卓伊凡解决方案
1079 7
|
安全 Linux 开发工具
零基础构建开源项目OpenIM桌面应用和pc web- Electron篇
OpenIM 为开发者提供开源即时通讯 SDK,作为 Twilio、Sendbird 等云服务的替代方案。借助 OpenIM,开发者可以构建安全可靠的即时通讯应用,如 WeChat、Zoom、Slack 等。 本仓库基于开源版 OpenIM SDK 开发,提供了一款基于 Electron 的即时通讯应用。您可以使用此应用程序作为 OpenIM SDK 的参考实现。本项目同时引用了 @openim/electron-client-sdk 和 @openim/wasm-client-sdk,分别为 Electron 版本和 Web 版本的 SDK,可以同时构建 PC Web 程序和桌面应用(Wi
1448 2