探索OpenNJet :快速上手下一代云原生应用引擎

2024-04-29 03:44

本文主要是介绍探索OpenNJet :快速上手下一代云原生应用引擎,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

  • 初识OpenNJet
  • OpenNJet 编译与安装
  • OpenNJet 使用教程
  • OpenNJet 产品体验感受

初识OpenNJet

OpenNJet最早是基于NGINX1.19基础,fork并独立演进的开源应用引擎,并随着NGINX版本迭代,吸收上游NGINX的更新,已经同步更新到NGINX1.23.1版本。OpenNJet的目标在于适应国内特定的技术规范及标准,如国密算法套件支持,并构建安全可控的云原生数据面,支撑我国云原生产业生态。作为底层引擎,OpenNJet利用动态加载机制可以实现不同的产品形态,如API网关、消息代理、出入向代理,负载均衡,WAF等等

想要了解更多可以查看OpenNJet官网链接:https://njet.org.cn/

OpenNJet 编译与安装

本文带大家使用CentOS 编译环境开发

  • 1.配置yum源

执行命令

sudo yum --enablerepo=extras install -q -y epel-release centos-release-scl-rh https://repo.ius.io/ius-release-el7.rpm

如图:
在这里插入图片描述

sudo curl -o /etc/yum.repos.d/mercurial.repo https://www.mercurial-scm.org/release/centos7/mercurial.repo

如图
在这里插入图片描述

如图:

ls -al /etc/yum.repos.d/mercurial.repo

在这里插入图片描述

  • 2.yum安装软件包
sudo yum install -y devtoolset-8-make devtoolset-8-toolchain ca-certificates mercurial zlib-devel cmake3 ninja-build libunwind-devel pcre-devel openssl-devel libtool libtool-ltdl

如图;
在这里插入图片描述

  • 3.创建符号连接
sudo ln -s /opt/rh/devtoolset-8/root/usr/bin/gcc /usr/local/bin/gcc
sudo ln -s /opt/rh/devtoolset-8/root/usr/bin/c++ /usr/local/bin/c++
sudo ln -s /opt/rh/devtoolset-8/root/usr/bin/cc /usr/local/bin/cc
sudo ln -s /opt/rh/devtoolset-8/root/usr/bin/make /usr/local/bin/make

如图:
在这里插入图片描述

  • 4.修改 ld.so.conf 配置
sudo bash -c 'echo "/usr/local/lib" >> /etc/ld.so.conf'
  • 5.上传压缩文件到home目录下

git仓库地址:https://github.com/OpenNJet/OpenNJet
可以下载zip文件

在这里插入图片描述

解压:

unzip OpenNJet-main.zip

在这里插入图片描述

编译

sh build_cc.sh conf

在这里插入图片描述

*执行:**make

make

执行成功截图如下:
在这里插入图片描述

OpenNJet 使用教程

  • 常用命令
 njet -h //显示帮助信息njet -p /tmpr/njet/ -c conf/njet.conf //启动​njet -t //测试配置信息是否有错误njet -v //显示版本njet -s stop 或者 kill -TERM {进程id} //快速停止njet -s reload 或者 kill -HUP {进程id}//重新加载配置
  • 正向代理

配置在客户端,客户端所有流量都通过正向代理去访问

指令介绍

proxy_connect
Syntax: proxy_connect Default: none Context: server
启用“ CONNECT”HTTP 方法支持。
proxy_connect_allow
Syntax: proxy_connect_allow all | [port ...] | [port-range ...] Default: 443 563 Context: server

此指令指定代理 CONNECT 方法可以连接到的端口号或范围的列表。 默认情况下,只启用默认的 https 端口(443)和默认的 snews 端口(563)。 使用此指令将覆盖此默认值,并仅允许连接到列出的端口。

All 值将允许所有端口进行代理。
给定值将允许指定的端口代理。
port-range 将允许指定的端口到代理的范围,例如:

Plaintext
proxy_connect_allow 1000-2000 3000-4000; # allow range of port from 1000 to 2000, from 3000 to 4000.

proxy_connect_connect_timeout
Syntax: proxy_connect_connect_timeout time Default: none Context: server

定义与代理服务器建立连接的超时。

代理配置示例
Example

Bash
server {listen 80;    //端口设定resolver 114.114.114.114; # dns解析服务器proxy_connect;proxy_connect_allow            443, 456;proxy_connect_connect_timeout  10s;location /{proxy_pass $scheme://$host$request_uri; #proxy_pass 用来要代理的网站,#$scheme是客户端请求的协议(如http,https);#$host是客户端请求的域名(如baidu.com);#$request_uri是客户端访问的url地址(如/baidu?s=12345)。#他们拼接成就是http://baidu.com/baidu?s=12345}}
}

客户端配置(win11系统为例)
在这里插入图片描述

OpenNJet 产品体验感受

当我第一次体验OpenNJet时,我被其在性能和灵活性方面的卓越表现所吸引。首先,OpenNJet基于NGINX引擎,利用了NGINX1.23.1版本的最新功能,为系统提供了出色的性能和稳定性。无论是处理大流量还是保障系统稳定运行,OpenNJet都表现出色。
其次,OpenNJet提供了丰富的功能模块,包括API网关、消息代理、出入向代理、负载均衡、WAF等,这些模块可以根据需求进行动态加载,为系统提供了极大的灵活性和可定制性。例如,我可以根据业务需求轻松地添加API网关和负载均衡功能,而不需要重新配置整个系统。

在实际使用中,我发现OpenNJet的易用性也很高。它提供了清晰的配置文件和详尽的文档,使得配置和管理变得非常简单和直观。我可以轻松地根据文档指引完成各种配置,而无需过多的技术背景知识。

对于新手来说,开始使用OpenNJet可能会感到有些挑战,但以下建议可以帮助他们更轻松地入门:

  • 学习基础知识: 在深入研究OpenNJet之前,建议新手先对相关的基础知识进行学习。这包括了解NGINX、云原生技术、网络代理等基本概念,这些知识将有助于理解OpenNJet的工作原理和使用方法。
  • 阅读文档和教程: OpenNJet提供了详细的文档和教程,新手可以通过阅读这些文档来了解OpenNJet的各种功能、配置和用法。务必花时间仔细阅读并理解文档中的内容,这将帮助您更快地掌握OpenNJet。
  • 尝试示例代码: OpenNJet的文档中通常会包含一些示例代码,新手可以尝试运行这些示例代码,以加深对OpenNJet的理解。通过实际操作,您可以更直观地了解OpenNJet的工作方式和效果。
  • 遵循最佳实践: 在使用OpenNJet时,建议新手遵循最佳实践和安全原则。例如,配置合适的安全策略、备份数据、定期更新系统等,这样可以提高系统的稳定性和安全性。
    参考资料
    开发指南https://gitee.com/njet-rd/docs/blob/master/zh-cn/CoPilot%E5%BC%80%E5%8F%91%E6%8C%87%E5%8D%97.md
    使用手册https://gitee.com/njet-rd/docs/blob/master/zh-cn/OpenNJet%E4%BD%BF%E7%94%A8%E6%89%8B%E5%86%8Cv2.1.0.md

这篇关于探索OpenNJet :快速上手下一代云原生应用引擎的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/945032

相关文章

k8s按需创建PV和使用PVC详解

《k8s按需创建PV和使用PVC详解》Kubernetes中,PV和PVC用于管理持久存储,StorageClass实现动态PV分配,PVC声明存储需求并绑定PV,通过kubectl验证状态,注意回收... 目录1.按需创建 PV(使用 StorageClass)创建 StorageClass2.创建 PV

k8s中实现mysql主备过程详解

《k8s中实现mysql主备过程详解》文章讲解了在K8s中使用StatefulSet部署MySQL主备架构,包含NFS安装、storageClass配置、MySQL部署及同步检查步骤,确保主备数据一致... 目录一、k8s中实现mysql主备1.1 环境信息1.2 部署nfs-provisioner1.2.

使用EasyPoi快速导出Word文档功能的实现步骤

《使用EasyPoi快速导出Word文档功能的实现步骤》EasyPoi是一个基于ApachePOI的开源Java工具库,旨在简化Excel和Word文档的操作,本文将详细介绍如何使用EasyPoi快速... 目录一、准备工作1、引入依赖二、准备好一个word模版文件三、编写导出方法的工具类四、在Export

利用Python操作Word文档页码的实际应用

《利用Python操作Word文档页码的实际应用》在撰写长篇文档时,经常需要将文档分成多个节,每个节都需要单独的页码,下面:本文主要介绍利用Python操作Word文档页码的相关资料,文中通过代码... 目录需求:文档详情:要求:该程序的功能是:总结需求:一次性处理24个文档的页码。文档详情:1、每个

k8s admin用户生成token方式

《k8sadmin用户生成token方式》用户使用Kubernetes1.28创建admin命名空间并部署,通过ClusterRoleBinding为jenkins用户授权集群级权限,生成并获取其t... 目录k8s admin用户生成token创建一个admin的命名空间查看k8s namespace 的

Java中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例解析

《Java中的分布式系统开发基于Zookeeper与Dubbo的应用案例解析》本文将通过实际案例,带你走进基于Zookeeper与Dubbo的分布式系统开发,本文通过实例代码给大家介绍的非常详... 目录Java 中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例一、分布式系统中的挑战二

Java 缓存框架 Caffeine 应用场景解析

《Java缓存框架Caffeine应用场景解析》文章介绍Caffeine作为高性能Java本地缓存框架,基于W-TinyLFU算法,支持异步加载、灵活过期策略、内存安全机制及统计监控,重点解析其... 目录一、Caffeine 简介1. 框架概述1.1 Caffeine的核心优势二、Caffeine 基础2

k8s搭建nfs共享存储实践

《k8s搭建nfs共享存储实践》本文介绍NFS服务端搭建与客户端配置,涵盖安装工具、目录设置及服务启动,随后讲解K8S中NFS动态存储部署,包括创建命名空间、ServiceAccount、RBAC权限... 目录1. NFS搭建1.1 部署NFS服务端1.1.1 下载nfs-utils和rpcbind1.1

使用Node.js和PostgreSQL构建数据库应用

《使用Node.js和PostgreSQL构建数据库应用》PostgreSQL是一个功能强大的开源关系型数据库,而Node.js是构建高效网络应用的理想平台,结合这两个技术,我们可以创建出色的数据驱动... 目录初始化项目与安装依赖建立数据库连接执行CRUD操作查询数据插入数据更新数据删除数据完整示例与最佳

k8s容器放开锁内存限制问题

《k8s容器放开锁内存限制问题》nccl-test容器运行mpirun时因NCCL_BUFFSIZE过大导致OOM,需通过修改docker服务配置文件,将LimitMEMLOCK设为infinity并... 目录问题问题确认放开容器max locked memory限制总结参考:https://Access