从GNU/Linux看国产操作系统的安全可控性

news2025/1/7 18:01:15

作者:IT圈黎俊杰

  在信创的春风下,做为IT基础软件三驾马车之一的操作系统,自然是国产化替代的重点,再加上一直以来被大家当成”免费RedHat Enterprise Linux“的CentOS因被redhat收购,并宣布于2021年12月31日起在停止维护CentOS Linux 8、 2024年6月30日开始停止维护CentOS Linux7事件后,使得操作系统国产化替代一度成为信创工作中的焦点需求。

  有句话叫“核弹研发难度远不如操作系统”,可见造操作系统是何等的不容易。那么,以当前国际Linux操作系统生态以及我国在操作系统方面的研发模式,自主品牌发行版Linux操作系统的自主可控性到底是怎么样的呢?

一、全球操作系统技术塑源与演进路线

  先对全球主流操作系统的诞生、技术来源与演进路线进行分析,下面是笔者分析绘制的示意图:

  Unix和MS-DOS,可以说是操作系统的开山鼻祖,是IT界操作系统的基础。

  笔者当年就是从MS-DOS开始学习计算机技术的,回想起当时学习MS-DOS时,全靠一张软盘,老师给一张母盘,同学们拿着它,你复制来我复制去,插进386电脑的软驱里,咔滋咔滋直作响,就像老牛拉破车一样,直到一行闪烁的光标出现,开启了我们的计算机学习之路。

  为了感谢教我们MS-DOS入门的老师们,以及回忆我们一起在咸宁教育学院寒窗苦读的同学们,在此秀一张我们毕业后聚会的师生照吧。

  上面有我们亲爱的叶老师(女,前一排左四,棕色上衣)和尹老师(男,前一排左五)。真是名师出高徒,同学们有的成为了企业老板、有的当上了企业高管与中层干部、还有好多同学当上了公务员和人民教师,感谢老师的辛勤培养。

  言归正传,因为国产操作系统基本都是基于Linux开发,属于类Unix系,所以本文不讨论MS-DOS和Windows部分。

  Unix系统的精华在于它的框架,每一个程序员都可以在其他人的基础上继续工作1956年,Unix所属的AT&T公司被美国联邦政府要求只能提供电信业务,所以AT&T公司对计算机业务不再热衷了,而Unix也就不再受到公司的资助,Unix已经演变成为一个无所有权的操作系统。到了二十世纪七十年代末期,AT&T公司突然认识到Unix还有一定的商业价值,因此他们就利用1956年的一项软件著作权声明想要把Unix声明成为自己的商业机密。从1979年的Unix第七个版本开始,Unix的许可协议不再允许大学里使用Unix源代码开设课程。而Vrije大学的计算机教授Andrew Tanenbaum说:“这不是个问题。”在1987年他编写了一个Unix的克隆版,并在他的课堂中使用它。在70年代,Bill Joy只是位加州大学伯克利分校的一位毕业生,他当时正从事程序员的工作,一次他从贝尔实验室收到一份Unix的拷贝,他发现这是一个很好的平台,可以运行他的Pascal编译器和文本编辑器,而后来他和他的同学们又编写了Unix的另外一个重要的分支,被称作Berkeley Software Distribution (BSD) Unix。随着时代的发展,Unix已被发展出多个分支,而BSD也再次被发展出Solaris(商业版本)和freeBSD(开源版本)两个分支。

  1983年,Richard Stallman(rms)发起意在为所有软件用户能够自由控制自己的计算而构建一款由大家共同努力开发而成,并且和Unix100%兼容的自由软件操作系统,取名为GNU(GNU's not unix),意思是“GNU不是UNIX”。设计时它有自己的内核叫 Hurd,并且开发很多软件包,包括以用户为导向的应用程序、实用程序、工具、应用库、游戏等,但很遣憾的是,它的内核一直未开发出来。

  1991年,芬兰赫尔辛基大学计算机系研究生LinusTorvalds(林纳斯·托瓦兹)因使用的Minix系统只能用于教学和价格让其望而却步,于是决定参考Unix开发一套自己的操作系统,1991年2月4日,Linux内核系统0.00版生。

  好了,GNU有着丰富的应用程序,但是无内核或是内核还不好用;Linux有着优质的内核,但是无应用程序

  “天仙配”开始了,就有了很多公司或组织,将GNU丰富的应用程序和Linux的强劲内核相结合,再加上自己的产品研发整合,形成了可用的操作系统,进行发行上市,fedora、openSUSE、debian等操作系统就此诞生了,称为GNU/Linux,这些属于世界第一梯队主流的Linux操作系统。

  出于商业的目的,让自己的操作系统开发变得更简单,借助巨人的肩膀,基于第一梯队fedora、openSUSE、debian等操作系统之上,再二次开发的redhat Linux、CentOS、SUSE、ubuntu等都相继发行了。

  android是个个例,因为公司技术能力强劲的原因吧,它完全独立基于Linux内核开发,并没有使用GNU的软件产品,所以目前所有Linux系操作系统中,只有它不是GNU/Linux。

  上面说的是全球的操作系统技术溯源及演进路线,对于发展中的国产操作系统的技术来源,本文不做描述。

二、主流国产操作系统有哪些

  有人说“国产的操作系统比用户都多”。主流国产操作系统主要有三大类,第一大类是由开源社区维护的开源类操作系统,第二大类是商业公司发行的商业操作系统,第三大类是商业公司发布的开源操作系统。

 (一)国内开源社区维护的开源操作系统

  国内开源社区维护的开源操作系统主要有三个,分别是如下:

  (1)华为公司主导的OpenEuler(欧拉)操作系统,由OpenEuler开源社区维护;

  (2)阿里公司主导的AnolisOS(龙蜥)操作系统,由OpenAnolis开源社区维护;

  (3)腾讯公司主导的OpenCloudOS操作系统,无中文名,由OpenCloudOS开源社区维护。

 国内操作系统开源社区都是近几年才开始建立,主导社区的公司在开源操作系统产品本身方面无商业利益,生态也在快速的完善,已有逐渐发展成为部分国产商业操作系统、企业自用操作系统的上游技术源头的趋势,既有用它做国产服务器操作系统的,也有用它做国产PC桌面与移动平板操作系统的。

 (二)商业公司发行的商业操作系统

  国产商业操作系统,主要有麒麟家族系列(银河麒麟、中标麒麟、优麒麟、麒麟信安)、统信、红旗、中兴新支点、中科方德、凝思、起点、深度等。这些操作系统有些品牌既发行有服务器类操作系统,也发布有PC桌面与移动平板操作系统。

 (三)国内商业公司发布的开源操作系统

  这类产品由于没有生态支持,所以用户非常非常少,几乎为被忽略的状态。

三、主流国产操作系统技术路线

  你要是问国产操作系统厂家,他的操作系统是基于国外产品二次开发的还是自主研发的,可能大部分厂家都会告诉你”他是100%自研的“,还有一些厂家会告诉你”他是直接在Linux内核基础之上自主开发的“。这么说的,都是骗子。

  当前国产操作系统的技术路线基本可分成四条,分别如下:

  第一条路线:做L1级产品,由国内厂商支持的开源社区,参与Linux内核代码贡献,再使用成熟的Linux内核+GNU+社区共研应用,形成的发行版操作系统,如华为的OpenEuler(欧拉)等。

  第二条路线:做L2级产品,在国外L1级(fedora、debian等)如和国内L1级(如OpenEuler等)产品的基础之上,再二次开发,同时自己也参与Linux内核和上游产品的代码贡献,而形成的发行版操作系统。国内采用这条路线的操作系统会越来越多。

  第三条路线:做L3级产品,在国外L2级(如CentOS stream、openSUSE等)和国内L2级(不方便写出名称)产品的基础之上,再二次开发,同时自己也参与Linux内核和上游产品的代码贡献,而形成的发行版操作系统。国内有一部分产品采用这条路线,既有商业操作系统,也有开源操作系统。

  有个别国产开源操作系统,它自身基于国外L2级开源操作系统二次开发而来的,却又再次开源出来给国产商业操作系统做发行版或某些企业做内部使用版的操作系统。这叫“只有想不到的,没有做不到的”。

  第四条路线:做L4级产品,基于国内开源操作系统版本之上,再来做自己的商业发行版或企业内部使用版。

  您用的国产操作系统属于上面第几条路线制造出来的产品,请您擦亮眼晴哦。

四、主流国产操作系统的安全可控性

  国产操作系统根据技术来源选用策略的不同,当前主要有下面四部分中的两到四部分的程序和代码来自全球,分别为:

  1、Linux内核代码:Linux内核代码来自以美国为首的全球贡献者,开源,基于它开发的产品也必须继续开源;

  2、GNU应用代码:GNU代码也一样来自以美国为首的全球贡献者,开源,基于它开发的产品也必须继续开源;

  3、XWindowSystem接口与图形化应用代码:如果要想使用图形化应用,还需要用到同样由美国为首的组织与公司主导的XWindowSystem图形化接口与KDE、Gnome等图形化应用软件及相关代码;

  4、国外L1或L2级开源操作系统代码:国外L1或L2级开源操作系统的自研代码,如fedora、CentOS stream、openSUSE、debian、ubuntu等;

  国产操作系统除了使用上述最少二到四部分的全球代码外,还有自己研发的代码,综合得出产品的自主率与安全可控性。

五、国产操作系统有必要继续吗

  当前没有任何一款国产操作系统做到了100%代码自主率是个不争的事实,但即便这样,笔者个人认为国产操作系统的研发还是非常有必要继续下去的,原因如下:

  1、从Linux内核级提升安全性:当前如果完全自主研发操作系统内核,国内还不具备这样的实力,即便研发,也有可能会跟GNU研发内核一样重蹈覆辙。而国产厂商与个人通过积极参与Linux内核的开发贡献,使得中国在Linux内核中的代码贡献比重越来越大,对我国来说使用Linux操作系统的安全性就越来越高。

  2、提升国产操作系统自主级别:通过操作系统应用功能的开发,一部分有实力的企业或社区组织,逐渐由基于国外的L1级发行版开源操作系统二次开发成自己的操作系统,提升为直接基于Linux内核+GNU开发,使得自己的产品晋级为L1级或基于国产L1级产品研发的L2级产品,大幅提升国产操作系统的自主率与安全可靠性。

  3、减少GNU进一步提升自主率:企业或社区组织,在能力达到一定程度后,要尽量减少对GNU组件的使用,甚至完全不使用GNU,采用只基于Linux内核,完全自主开发应用,而发行的操作系统,如Android系统。国内操作系统厂商或开源社区还需要较长的时间积累与技术沉淀。

  4、为自主操作系统内核而努力:在足够的时间沉淀与技术积累之后,国内企业或社区组织能够完全自主研发一种新型的操作系统内核,并基于自主的内核开发出发行版操作系统、建立起完善的生态。

希望我国通过信创工作,能够培训出一批高技术能力的企业和社区组织,实现国产操作系统的高度自主率,甚至打造出完全国产的操作系统内核(要防止“换皮内核”),把我国建设成全球信息技术能力大国强国。

  坚持原创发表,如发现有不妥与不正确之处,欢迎指正。IT圈黎俊杰虚心向大家学习!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/84218.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

SpringBoot+SpringCloud微服务搭建全过程(一)

一:什么是SpringBoot 1. SpringBoot不是一个全新的框架,而是对Spring框架的一个封装。所以,以前Spring可以做的事情,现在用SpringBoot都可以做。 2. SpringBoot整合了很多优秀的框架,用来简化Spring应用搭建和开发过程&#xff…

java项目_第171期ssm房屋租赁系统_计算机毕业设计

java项目_第171期ssm房屋租赁系统_计算机毕业设计 【源码请到下载专栏下载】 今天分享的项目是《ssm房屋租赁系统》 该项目分为2个角色,管理员和用户。 用户可以浏览前台,查看房屋租赁情况,并且进行租赁。 还可以登录到后台,进行租赁订单管理…

【20221212】【每日一题】一和零

给你一个二进制字符串数组 strs 和两个整数 m 和 n 。 请你找出并返回 strs 的最大子集的长度,该子集中 最多 有 m 个 0 和 n 个 1 。 如果 x 的所有元素也是 y 的元素,集合 x 是集合 y 的 子集 。 思路:背包有两个维度:m、n。不…

【工作项目总结】交易系统

写工作项目总结的目的就是,明明自己工作中负责了一些模块也写了很多代码,解决了不少坑。但是面试的时候,总是记不起来在自己过往做的项目中,该项目的具体亮点难点分别是什么,有哪些令人印象深刻的问题,以及是如何解决它的。那么记录问题与解决思维就是我创作这个工作复盘…

C#连接蓝牙设备

看过各种博主的文章,发现基本上都是属于误人子弟的狗屁文章,踩过各种坑最终实现了此功能。 1.思路 电脑蓝牙和蓝牙模块配对连接 和我们平时正常连接蓝牙设备一样,需要先搜索附近的蓝牙设备,然后根据设备名来选择要连接的蓝牙模块…

VSCODE 系列(六)使用Plantuml插件制作UML类图

文章目录前言下载和安装支持文件格式支持绘制类型导出语法申报要素UML类图关系参考例子参考前言 软件设计中,有好几种图需要画,比如流程图、类图、组件图等,我知道大部分人画流程图一般都会用微软的visio绘制,visio画图有个不好的…

[附源码]计算机毕业设计高校实验室仪器设备管理系统Springboot程序

项目运行 环境配置: Jdk1.8 Tomcat7.0 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 项目技术: Springboot mybatis MavenVue等等组成,B/S模式…

Java学习笔记 --- 反射

一、反射机制 Java Reflection 1、反射机制允许程序在执行期间借助于 ReflectionAPI取得任何类的内部信息(比如成员变量,构造器,成员方法等),并能操作对象的属性及方法。反射在设计模式和框架底层都会用到 2、加载完…

数学基础从高一开始6、全称量词与存在量词

数学基础从高一开始6、全称量词与存在量词 目录 数学基础从高一开始6、全称量词与存在量词 全称量词 存在量词 1.判断命题的真假 2.判断命题的真假 阅读下列两组命题,语言上有什么特点? A组: (1)对任意一个x∈Z,2x1是整数; (2)每一个素…

Pod使用进阶

Pod使用进阶 封面 写在前面 语雀上阅读效果更佳,请访问如下地址: 197 Pod使用进阶 语雀 《197 Pod使用进阶》 1、Pod 资源配置 实际上上面几个步骤就是影响一个 Pod 生命周期的大的部分,但是还有一些细节也会在 Pod 的启动过程进行设置&…

Hive 计算用户留存率(次日,3日,N日)

文章目录什么是用户留存率?创建数据源计算留存率计算 N 日的留存率什么是用户留存率? 用户留存率是指在特定时间段内,用户在使用某个产品或应用程序后,再次使用该产品或应用程序的比例。 它可以帮助公司了解用户是否喜欢他们的产…

2022 第十四届蓝桥杯模拟赛第二期题目题解(比赛时使用方法)

目录 第一题:最小的2022 第二题:经过天数 第三题:特殊的十六进制数 第四题:矩阵的最小路径 第五题:质数拆分 第六题:拷贝时间 第七题:单词去重 第八题:最短回文串 第九题&a…

[附源码]Node.js计算机毕业设计大学校园二手教材与书籍Express

项目运行 环境配置: Node.js最新版 Vscode Mysql5.7 HBuilderXNavicat11Vue。 项目技术: Express框架 Node.js Vue 等等组成,B/S模式 Vscode管理前后端分离等等。 环境需要 1.运行环境:最好是Nodejs最新版,我…

GoWeb 优雅的 ORM 框架之 GORM,实现 MySQL 数据库的增删改查等操作(附案例全代码)

1、前言 什么是web应用,Web应用程序简单流程如下图所示 通过上图我们发现,我们 GoWeb 实战项目还缺少最后关键的环节数据库。那么如何使用 GO 语言操作数据库并完成增删改查等操作是我们今天学习的目标。 GoWeb 的 MVC 入门实战案例,基于 Iris 框架实现(附案例全代码) …

[附源码]Python计算机毕业设计Django的连锁药店销售管理系统

项目运行 环境配置: Pychram社区版 python3.7.7 Mysql5.7 HBuilderXlist pipNavicat11Djangonodejs。 项目技术: django python Vue 等等组成,B/S模式 pychram管理等等。 环境需要 1.运行环境:最好是python3.7.7,…

11.校验token和解析token获取数据代码优化

校验token和解析token获取数据代码优化 解决方案 基于ThreadLocal 拦截器的形式统一处理 一、使用拦截器进行统一身份鉴权 1.1定义拦截器 package com.tanhua.server.interceptor;import com.tanhua.commons.utils.JwtUtils; import org.springframework.web.servlet.Handl…

[附源码]Nodejs计算机毕业设计基于java旅游信息分享网站Express(程序+LW)

该项目含有源码、文档、程序、数据库、配套开发软件、软件安装教程。欢迎交流 项目运行 环境配置: Node.js Vscode Mysql5.7 HBuilderXNavicat11VueExpress。 项目技术: Express框架 Node.js Vue 等等组成,B/S模式 Vscode管理前后端分…

二、物理层(一)通信基础

目录 1.1通信基础概念 1.2传输方式 1.2.1串行传输和并行传输 1.2.2单工通信、半双工通信和全双工通信 1.3编码与调制 1.3.1数字数据编码为数字信号 1.3.2数字数据调制为模拟信号 1.3.3模拟信号编码为数字信号 1.3.4模拟数据调制为模拟信号 1.4电路交换、报文交换与分…

装了就不舍得卸载,4款电脑必装软件,功能实用又免费

下面4款电脑软件,每一个都是你绝对能用得上的神器,可遇不可求。 1、AutoOff AutoOff是一款完全免费,纯绿色的电脑操作定时工具,功能强大且实用,体积不到1M,非常小巧,支持自动关机、重启、休眠、…

Mysql批量插入对比(附github仓库demo)

前言 本文记录个人使用MySQL插入大数据总结较实用的方案,通过对常用插入大数据的4种方式进行测试, for循环单条拼接SQL批量插入saveBatch()循环 开启批处理模式 最近趁空闲之余,在对MySQL数据库进行插入数据测试 准备工作 测试环境&…