`
Cwind
  • 浏览: 266399 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
博客专栏
793bb7df-a2a9-312d-8cb8-b66c3af482d1
LeetCode题解
浏览量:53920
社区版块
存档分类
最新评论

在CentOS5.5上编译OpenJDK6

阅读更多

几番周折终于在自己的CentOS5.5上编译成功了OpenJDK6,将编译过程和遇到的问题作一简要记录,备查。

0. OpenJDK介绍

OpenJDK是Sun(现Oracle)公司发布的基于GPL许可的Java平台的实现。其优点:

1、它的核心代码与同时期Sun(-> Oracle)的产品版基本上是一样的,血统纯正,不用担心性能问题,也基本上没什么兼容性问题;(代码上最主要的差异是在原本JDK依赖的第三方库上,包括加密库、音频库、字体等。核心部分,也就是HotSpot VM与Java核心库基本上保持了Sun JDK的原貌,甚至还比Sun JDK更快的吸收社区反馈的贡献)

2、它是真正开源的,许可证是GPLv2+CE,使用上比原本JDK的另外两种许可证要自由一些;

3、由于考虑到社区的开发者的build环境需求,OpenJDK的构建系统比原本的JDK有大幅改进,使整个build过程变得非常轻松。

--引自师兄RednaxelaFX的博客文章

编译过程参考了许多文章,详见附录。不像其他多数文章一样只是单纯的第一步敲什么命令第二步敲什么命令,RednaxelaFX的笔记尤其详细,从背景到各依赖项和配置项都说得很明白。强烈建议参考。

前一类的文章只有命令没有解释,遇到由于链接失效或版本不匹配的情况,命令执行不下去。新手如果不擅长从错误日志中分析原因往往就会卡个半天。所以方法论层面的东西就显得尤为重要。

我们的需求:在Linux XX 发行版(版本号xx)上编译OpenJDK x

基本步骤:

1. 下载OpenJDK x源码 http://download.java.net/openjdk/

2. 参考相应源码中的Build README,了解所需编译环境、依赖包

3. 安装依赖包

4. 环境配置

5. 健全性检查

6. 编译

最后的编译过程视配置情况从十几分钟到几小时不等,困难之处在解决3、4、5步骤中可能会遇到的各种问题。

同一个解决方案不适用于不同的Linux发行版本,甚至不适用于同一个发行版本的两个小版本;OpenJDK的版本、以及各个依赖包的版本都会有影响;

主要的错误都在于缺少某个依赖包、缺少某个特定版本的依赖包、缺少某个头文件、找不到某个特定类型--基本上都属于依赖包缺失导致的。

学会通过错误日志发现并解决问题才是更重要更有益的。

下面以本人在CentOS5.5上编译OpenJDK6的过程来具体说明:

1. 下载OpenJDK6源码

http://download.java.net/openjdk/jdk6/ 


2. 查看README,了解编译环境和所需依赖包

http://hg.openjdk.java.net/jdk6/jdk6/raw-file/tip/README-builds.html

这个文档中没有针对CentOS的编译环境的专门说明,只有针对Fedroa的。由于CentOS是RHEL(RedHat Enterprise Linux)去掉redhat标志重新编译的Linux版本,与RHEL很接近,而Fedroa又是RedHat公司支持的社区版,因此可以参照Fedroa的环境配置CentOS


Fedora 9
After installing Fedora 9 you need to install several build dependencies. The simplest way to do it is to execute the following commands as user root:
yum-builddep java-1.6.0-openjdk
yum install gcc gcc-c++
In addition, it's necessary to set a few environment variables for the build:
export LANG=C ALT_BOOTDIR=/usr/lib/jvm/java-openjdk
可见,要编译OpenJDK,首先需要一个JDK(作为Bootstrap JDK, 否则Ant等工具无法运行),然后需要gcc/g++等编译器,同时需要设置相应的环境变量,取消JAVA_HOME(unset JAVA_HOME)的设置,将ALT_BOOTDIR指向已有jdk所在目录

在README文档中的Build Dependencies一节中可以看到编译所需的依赖包

Ant,构建工具,注意对它的版本也有要求;README中提到至少要1.7.1,而在实际编译中需要1.8.2以上

gcc, 版本4.0以上

CUPS(Common Unix Printing System,通用Unix打印系统)的头文件

Motif, 由开放基金协会OSF开发的一个工业标准GUI的相关头文件

FreeType, 一个开源的字体引擎,提供统一的接口来访问字体格式文件,要求版本2.3以上

ALSA(Advanced Linux Sound Architecture,高级Linux声音架构),为Linux提供音频和MIDI支持。要求版本0.9以上

Xorg,Xorg基金会的X11开源实现


3. 安装依赖包

其实建议的方法是在下载完代码和安装好Bootstrap JDK和Ant之后直接使用make sanity进行健全性检查。此时由于缺少Build Dependencies中的依赖包理所当然地会报出非常多的错误。根据错误日志中提示缺少的具体包和具体版本再进行安装

安装依赖包首选通过yum install直接安装;但yum源上有时没有指定版本的rpm,这就需要单独下载安装了(例如Ant1.8和FreeType2.3)。每个所需依赖包的安装又可以单独用一篇帖子介绍,主要是各自又存在软件包的依赖性问题。一般来说,建议下载源码进行编译,这样有错误比较容易检查;下载rpm包安装容易陷入无限的依赖循环中去。


3.0 gcc

yum install gcc gcc-c++

3.1 alsa

yum install alsa-lib alsa-lib-devel 

3.2 cups

yum install cups-devel

3.3 libXi

yum install libXi libXi-devel

3.4 xorg

yum install xorg-X11

3.5 freetype

wget http://download.savannah.gnu.org/releases/freetype/freetype-2.3.12.tar.gz

tar -xvf freetype-2.3.12.tar.gz

cd freetype-2.3.12

./configure && make && make install

3.6 ant

wget http://mirror.bit.edu.cn/apache//ant/binaries/apache-ant-1.8.2-bin.zip

解压,配置ANT_HOME

3.7 motif

yum install openmotif

yum install openmotif-devel

3.8 ant-nodeps

yum install ant-nodeps

3.9 libXtst

yum install libXtst

yum install libXtst-devel


4. 环境配置

export ALT_BOOTDIR=Bootstrap JDK目录

export ANT_HOME=ant安装目录

export ALT_FREETYPE_HEADERS_PATH=/usr/local/include/freetype2 #freetype2头文件安装目录

export ALT_FREETYPE_LIB_PATH=/usr/local/lib #freetype2 lib目录

要为所有用户设定这些环境变量,可将上述语句添加到/etc/profile中。修改环境变量的方式在此不赘述

不要忘记README中的 export LANG=C和unset JAVA_HOME


5. 健全性检查

在下载的OpenJDK源码目录中执行make sanity进行检查。

输出Sanity check passed.表示检查通过


6. 执行编译

在健全性检查通过后,可以通过make执行编译

make all ARCH_DATA_MODEL=64 ALLOW_DOWNLOADS=true


7. 问题排查

如前所述,在安装了README中所述的依赖包之外,还会因为各自的环境不同报缺少依赖包或缺少头文件等问题。

7.1缺少依赖包

一种情况是能够直接在yum源上找到,如ant-nodeps, lXtst;参见3.8、3.9

另一种情况是yum源上找不到,或者源上的版本比较旧,如ant, freetype;参见3.5、3.6

7.2 缺少头文件

如缺少motif相关头文件、CUPS相关头文件等;日志不会提示缺少哪个包,只提示缺少具体的某个头文件,如"AtomMgr.h"

须先通过yum provides AtomMgr.h查看缺少的头文件在哪个软件包中,然后再yum install安装该软件包

极端情况yum provides找不到头文件归属,此时请自行Google

笔者实际遇到的问题:

健全检查时:

1. 缺少freetype2.3

2. 缺少AtomMgr.h

3. 缺少CUPS.h

编译时:

1. Could not create task or type of type: replaceregexp

参见:http://stackoverflow.com/questions/8944128/ants-optional-tasks-are-not-available-on-centos

Missing regexp.jar

yum install ant-nodeps

2. /usr/bin/ld: cannot find -lXtst

解决方案在正文中已经全部提过了。

不管遇到什么问题,要从该问题产生的本质去思考去排查。

方法论比方法重要。渔比鱼重要。


Reference:

1. 在XUbuntu 10.10上以JRL源码构建Oracle JDK 6 update 23, http://rednaxelafx.iteye.com/blog/875957

2. Wikipedia: OpenJDK, http://en.wikipedia.org/wiki/OpenJDK

3. OpenJDK 6 Build README, http://hg.openjdk.java.net/jdk6/jdk6/raw-file/tip/README-builds.html

4. centos 5 5.3 编译openjdk 7, http://hi.baidu.com/jongsuny/item/dfc96c2dce1a029bb73263dd

5. OpenJDK编译手记, http://khotyn.iteye.com/blog/1225348


文中所有链接及参考资料在本文发布之时均验证可用

1
2
分享到:
评论

相关推荐

    centsos6.5+jdk1.7+mysql5.5+tomcat7+nginx1.7安装手册

    ### CentOS 6.5 + JDK 1.7 + MySQL 5.5 +...以上步骤为在CentOS 6.5上安装JDK 1.7和MySQL 5.5的基本过程。需要注意的是,在实际操作过程中可能会遇到各种问题,比如依赖库缺失等,这时需要根据错误提示进行相应的处理。

    Linux环境搭建 Apche+Tomcat 集群负载均衡

    - **操作系统**:CentOS 5.5 - **Apache版本**:2.4.7 - **Tomcat版本**:7.0.47 - **JDK版本**:1.7.0_45 - **JK Connector版本**:1.2.37 #### 四、部署步骤 ##### 1. 准备阶段 - 安装CentOS操作系统。可以选择...

    TinyYolo2实时视频流物体检测ONNX模型

    TinyYolo2实时视频流物体检测ONNX模型 运行 ONNX 模型,并结合 OpenCV 进行图像处理。具体流程包括: 1. 加载并初始化 ONNX 模型。 2. 从摄像头捕获实时视频流。 3. 对每一帧图像进行模型推理,生成物体检测结果。 4. 在界面上绘制检测结果的边界框和标签。

    chromedriver-linux64-134.0.6998.23(Beta).zip

    chromedriver-linux64-134.0.6998.23(Beta).zip

    Web开发:ABP框架4-DDD四层架构的详解

    Web开发:ABP框架4-DDD四层架构的详解

    chromedriver-linux64-135.0.7029.0(Canary).zip

    chromedriver-linux64-135.0.7029.0(Canary).zip

    (参考项目)MATLAB人脸门禁系统.zip

    实现人脸识别的考勤门禁系统可以分为以下步骤: 1. 采集人脸图像数据集:首先需要采集员工的人脸图像数据集,包括正面、侧面等多个角度的图像。可以使用MATLAB中的图像采集工具或者第三方库进行采集。 2. 预处理人脸图像数据:对采集到的人脸图像数据进行预处理,包括人脸检测、人脸对齐、人脸裁剪等操作。MATLAB提供了相关的图像处理工具箱,可以用于实现这些处理步骤。 3. 特征提取与特征匹配:使用人脸识别算法提取人脸图像的特征,比如使用人脸识别中常用的特征提取算法如Eigenfaces、Fisherfaces或者基于深度学习的算法。然后将员工的人脸数据与数据库中的人脸数据进行匹配,判断是否为注册员工。 4. 考勤记录与门禁控制:如果人脸匹配成功,系统可以记录员工的考勤时间,并且控制门禁系统进行开启。MATLAB可以与外部设备进行通信,实现门禁控制以及考勤记录功能。

    rdtyfv、ijij

    yugy

    企业IT治理体系规划.pptx

    企业IT治理体系规划.pptx

    基于Nutz、SSH、SSM的新闻管理系统.zip(毕设&课设&实训&大作业&竞赛&项目)

    项目工程资源经过严格测试运行并且功能上ok,可实现复现复刻,拿到资料包后可实现复现出一样的项目,本人系统开发经验充足(全栈全领域),有任何使用问题欢迎随时与我联系,我会抽时间努力为您解惑,提供帮助 【资源内容】:包含源码+工程文件+说明等。答辩评审平均分达到96分,放心下载使用!可实现复现;设计报告也可借鉴此项目;该资源内项目代码都经过测试运行,功能ok 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 【提供帮助】:有任何使用上的问题欢迎随时与我联系,抽时间努力解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 下载后请首先打开说明文件(如有);整理时不同项目所包含资源内容不同;项目工程可实现复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用

    基于多目标粒子群算法的冷热电联供综合能源系统优化调度与运行策略分析,基于多目标粒子群算法的冷热电联供综合能源系统优化调度与运行策略分析,MATLAB代码:基于多目标粒子群算法冷热电联供综合能源系统运行

    基于多目标粒子群算法的冷热电联供综合能源系统优化调度与运行策略分析,基于多目标粒子群算法的冷热电联供综合能源系统优化调度与运行策略分析,MATLAB代码:基于多目标粒子群算法冷热电联供综合能源系统运行优化 关键词:综合能源 冷热电三联供 粒子群算法 多目标优化 参考文档:《基于多目标算法的冷热电联供型综合能源系统运行优化》 仿真平台:MATLAB 平台采用粒子群实现求解 优势:代码注释详实,适合参考学习,非目前烂大街的版本,程序非常精品,请仔细辨识 主要内容:代码构建了含冷、热、电负荷的冷热电联供型综合能源系统优化调度模型,考虑了燃气轮机、电制冷机、锅炉以及风光机组等资源,并且考虑与上级电网的购电交易,综合考虑了用户购电购热冷量的成本、CCHP收益以及成本等各种因素,从而实现CCHP系统的经济运行,求解采用的是MOPSO算法(多目标粒子群算法),求解效果极佳,具体可以看图 ,核心关键词: 综合能源系统; 冷热电三联供; 粒子群算法; 多目标优化; MOPSO算法; 优化调度模型; 燃气轮机; 电制冷机; 锅炉; 风光机组; 上级电网购售电交易。,基于多目标粒子群算法的CCHP综合

    DSP28379D串口升级方案:单核双核升级与Boot优化,C#上位机开发串口通信方案,DSP28379D串口升级方案:单核双核升级与Boot优化,C#上位机开发实现串口通信,DSP28379D串口升

    DSP28379D串口升级方案:单核双核升级与Boot优化,C#上位机开发串口通信方案,DSP28379D串口升级方案:单核双核升级与Boot优化,C#上位机开发实现串口通信,DSP28379D串口升级方案 单核双核升级,boot升级,串口方案。 上位机用c#开发。 ,DSP28379D; 串口升级方案; 单核双核升级; boot升级; 上位机C#开发,DSP28379D串口双核升级方案:Boot串口升级技术使用C#上位机开发

    基于ASP.NET MVC+三层架构和EntityFramework的微博门户网站项目.zip(毕设&课设&实训&大作业&竞赛&项目)

    项目工程资源经过严格测试运行并且功能上ok,可实现复现复刻,拿到资料包后可实现复现出一样的项目,本人系统开发经验充足(全栈全领域),有任何使用问题欢迎随时与我联系,我会抽时间努力为您解惑,提供帮助 【资源内容】:包含源码+工程文件+说明等。答辩评审平均分达到96分,放心下载使用!可实现复现;设计报告也可借鉴此项目;该资源内项目代码都经过测试运行,功能ok 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 【提供帮助】:有任何使用上的问题欢迎随时与我联系,抽时间努力解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 下载后请首先打开说明文件(如有);整理时不同项目所包含资源内容不同;项目工程可实现复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用

    基于PLC的双层自动门控制:光电传感触发,有序开关与延时功能实现,附程序、画面及参考文档 ,基于PLC的双层自动门控制系统:精准控制,保障无尘环境;门间联动,智能安防新体验 ,基于plc的双层自动门控

    基于PLC的双层自动门控制:光电传感触发,有序开关与延时功能实现,附程序、画面及参考文档。,基于PLC的双层自动门控制系统:精准控制,保障无尘环境;门间联动,智能安防新体验。,基于plc的双层自动门控制系统,全部采用博途仿真完成,提供程序,画面,参考文档,详情见图。 实现功能(详见上方演示视频): ① 某房间要求尽可能地保持无尘,在通道上设置了两道电动门,门1和门2,可通过光电传感器自动完成门的打开和关闭。 门1和门2 不能同时打开。 ② 第 1 道门(根据出入方向不同,可能是门 1 或门 2),是由在通道外的开门者通过按开门按钮打开的,而第 2 道门(根据出入方向不同,可能是门 1 或门 2 )则是在打开的第 1 道门关闭后自动地打开的(也可以由通道内的人按开门按钮来打开第2 道门)。 这两道门都是在门开后,经过 3s 的延时而自动关闭的。 ③ 在门关闭期间,如果对应的光电传感器的信号被遮断,则门立即自动打开。 如果在门外或者在门内的开门者按对应的开门按钮时,立即打开。 ④ 出于安全方面的考虑,如果在通道内的某个人经过光电传感器时,对应的门已经打开,则通道外的开门者可以不按开门按钮。

    黑马程序员Java品达通用权限项目,基于SpringCloud SpringBoot 的微服务框架的权限管理解决方案.zip

    项目工程资源经过严格测试运行并且功能上ok,可实现复现复刻,拿到资料包后可实现复现出一样的项目,本人系统开发经验充足(全栈全领域),有任何使用问题欢迎随时与我联系,我会抽时间努力为您解惑,提供帮助 【资源内容】:包含源码+工程文件+说明等。答辩评审平均分达到96分,放心下载使用!可实现复现;设计报告也可借鉴此项目;该资源内项目代码都经过测试运行,功能ok 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 【提供帮助】:有任何使用上的问题欢迎随时与我联系,抽时间努力解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 下载后请首先打开说明文件(如有);整理时不同项目所包含资源内容不同;项目工程可实现复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用

    DeepSeek+DeepResearch-让科研像聊天一样简单

    DeepSeek+DeepResearch——让科研像聊天一样简单 (1)DeepSeek如何做数据分析? (2)DeepSeek如何分析文件内容? (3)DeepSeek如何进行数据挖掘? (4)DeepSeek如何进行科学研究? (5)DeepSeek如何写综述? (6)DeepSeek如何进行数据可视化? (7)DeepSeek如何写作润色? (8)DeepSeek如何中英文互译? (9)DeepSeek如何做降重? (10)DeepSeek论文参考文献指令 (11)DeepSeek基础知识。

    基于springboot+uniapp实现的蛋糕商城小程序.zip(毕设&课设&实训&大作业&竞赛&项目)

    项目工程资源经过严格测试运行并且功能上ok,可实现复现复刻,拿到资料包后可实现复现出一样的项目,本人系统开发经验充足(全栈全领域),有任何使用问题欢迎随时与我联系,我会抽时间努力为您解惑,提供帮助 【资源内容】:包含源码+工程文件+说明等。答辩评审平均分达到96分,放心下载使用!可实现复现;设计报告也可借鉴此项目;该资源内项目代码都经过测试运行,功能ok 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 【提供帮助】:有任何使用上的问题欢迎随时与我联系,抽时间努力解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 下载后请首先打开说明文件(如有);整理时不同项目所包含资源内容不同;项目工程可实现复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用

    jdepend-demo-2.9.1-10.el7.x64-86.rpm.tar.gz

    1、文件内容:jdepend-demo-2.9.1-10.el7.rpm以及相关依赖 2、文件形式:tar.gz压缩包 3、安装指令: #Step1、解压 tar -zxvf /mnt/data/output/jdepend-demo-2.9.1-10.el7.tar.gz #Step2、进入解压后的目录,执行安装 sudo rpm -ivh *.rpm 4、更多资源/技术支持:公众号禅静编程坊

    关爱儿童公益网站 web 项目.zip

    项目工程资源经过严格测试运行并且功能上ok,可实现复现复刻,拿到资料包后可实现复现出一样的项目,本人系统开发经验充足(全栈全领域),有任何使用问题欢迎随时与我联系,我会抽时间努力为您解惑,提供帮助 【资源内容】:包含源码+工程文件+说明等。答辩评审平均分达到96分,放心下载使用!可实现复现;设计报告也可借鉴此项目;该资源内项目代码都经过测试运行;功能ok 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 【提供帮助】:有任何使用上的问题欢迎随时与我联系,抽时间努力解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 下载后请首先打开说明文件(如有);整理时不同项目所包含资源内容不同;项目工程可实现复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用

    MATLAB实现WOA-LSTM鲸鱼算法优化长短期记忆网络数据分类预测(含模型描述及示例代码)

    内容概要:本文档详细介绍了如何利用 MATLAB 实现鲸鱼优化算法 (WOA) 和长短期记忆网络 (LSTM) 相结合的技术——WOA-LSTM,在数据分类和预测领域的应用。文章首先概述了LSTM在网络训练中超参数依赖的问题以及WOA作为一种新颖的全局优化算法的优势。接着阐述了该项目的研究背景、目的及其重要意义,并深入讨论了项目面临的六大主要挑战,从模型优化到超参数空间管理。文档特别强调WOA-LSTM融合所带来的性能提升、降低计算复杂度的能力及其实现自动化的超参数优化流程。除此之外,文中展示了模型的应用广泛性,覆盖了从金融市场的股票预测到智能制造业的各种实际场景,并提供了具体的模型架构细节和代码实例,以帮助理解模型的工作原理和技术要点。 适合人群:具有一定编程技能的研究人员、工程师和科学家们,尤其是对深度学习技术和机器学习感兴趣的专业人士。 使用场景及目标:该文档的目标是向用户传授使用MATLAB实现WOA-LSTM进行复杂数据分类和预测的方法论,旨在指导读者理解和掌握如何利用WOA进行超参数寻优,从而改善LSTM网络性能。 其他说明:通过阅读这份文档,使用者不仅能够获得有关WOA-LSTM技术的具体实现方式的知识,而且还可以获取关于项目规划和实际部署过程中的宝贵经验。

Global site tag (gtag.js) - Google Analytics