[经验分享] 【工作准备】(二)配置OpenHarmony下载、编译代码环境 原创 精华

诚迈_雨哥 显示全部楼层 发表于 2024-1-27 19:43:53

前言

虚拟机安装了,想要下载OpenHarmony代码、编译还缺少多个安装包(依赖库),请按照如下操作配置 OpenHarmony 虚拟机环境。

一、 安装路线

二、避坑指南

1. 使用个人邮箱还是公司邮箱

  • 如果是公司雇员,一定要咨询主管采用个人邮箱还是公司邮箱登记,避免不必要的麻烦;
  • 学生或者兴趣爱好者则使用个人账号;
  • 邮箱主要用来验证密码、收取码云的通知。例如:跑门禁通过,邮箱则会受到一封邮件;

2. 缺少某个依赖包,报错怎么办

  • 编译的时候难免缺少某个依赖包,结果报告一大堆错误。不要着急,找到最先出错的地方,或者在 ./out/rk3568/build.log 文件中搜索 error:,查看到底缺少什么安装包,有时会直接提示你安装某个安装包会解决此问题;
  • 安装的一般方式:$ sudo apt-get install xxx

3. 编译出错,无法解决怎么办

  • 申请加入welink “开放原子开源基金会”群,在群里求助;
  • 非个人环境造成的编译失败问题,一般会有人已经抛出了此问题,静观其变就好了;

三、配置环境前的准备

3.1 申请码云账号

https://dco.openharmony.io/sign/Z2l0ZWUlMkZvcGVuX2hhcm1vbnk=

1)打开上述网址,点击签署DCO。【必须签署】

env1.png

2)填写个人信息,签署DCO

env2.png

3.2 修改镜像源

点击如下列图所示,逐步操作。

1) 打开附件驱动

env3.png

2) 选择ubuntu下载服务器

env4.png

3) 选择华为镜像源

env6.png

4) 输入密码完成验证

env5.png

5) 选择重新载入

env7.png

6) 更新软件缓存

env8.png

3.3 安装git

在终端执行以下语句:

$ git config --global user.name "yourname"
$ git config --global user.email "your-email-address"

3.4 码云 SSH 公钥设置

3.4.1 参见官方指导文档

https://help.gitee.com/base/account/SSH%E5%85%AC%E9%92%A5%E8%AE%BE%E7%BD%AE

3.4.2 操作摘要

首先,登录码云gitee

第一步,手工生成 sshkey

$ ssh-keygen -t rsa -C xxxxx@xxxxx.com 出现Enter file后路径回车到底。

第二步,查看sshkey

$ cat ~/.ssh/id_rsa.pub

第三步,复制如下内容粘贴至gitee「个人设置」->「安全设置」->「SSH 公钥」

ssh-rsa ............@mail.com

3.4.3 检查SSH添加是否生效

$ ssh -T git@gitee.com

env9.png

四、正式配置环境

4.1 手动配置标准系统环境——针对RK3568系列

1)安装 Linux依赖包

sudo apt-get update && sudo apt-get install bc binutils binutils-dev bison build-essential ccache cpio curl default-jdk default-jre device-tree-compiler docker dosfstools dpkg-dev e2fsprogs fakeroot flex g++  gcc gcc-9-arm-linux-gnueabi gcc-arm-linux-gnueabi genext2fs git git-lfs gnupg gnutls-bin gperf lib32ncurses-dev lib32z1-dev libc6-dev-i386 libc6-dev-x32 libdwarf-dev libelf-dev libffi-dev libgl1-mesa-dev liblz4-tool libncurses5 libreadline-dev libssl-dev libtinfo5 libunwind-dev libx11-dev libxcursor-dev libxinerama-dev libxml2-utils libxrandr-dev locales m4 make mtd-utils mtools net-tools nfs-kernel-server nodejs npm openssl perl pkg-config python2 python3.8 python3-distutils python3-apt python3-distutils python3-minimal python3-pip python3-setuptools ruby samba scons smbclient ssh texinfo tree tzdata u-boot-tools unzip vim wget x11proto-core-dev xsltproc zip zlib1g-dev -y

2)安装 python依赖包

sudo pip3 install setuptools kconfiglib pycryptodome ecdsa

4.2 SH脚本自动配置L1小型系统环境——一键安装

特别感谢大佬奉献,让枯燥的工作变的高效。首先安装samba映射Ubuntu 文件到Windows,然后将以下脚本粘贴到 install.sh 文件中,拷贝到Ubuntu,用 chmod 777 ./install.sh 修改权限,然后执行即可。

#!/bin/bash
echo "Enter your email: "  
read YOUR_EMAIL
echo "Enter your name for git"
read YOUR_NAME

sudo apt update

sudo apt install dosfstools mtools mtd-utils default-jre default-jdk python3.8 python3-setuptools python3-pip git git-lfs zip -y

sudo rm -f /bin/sh
sudo ln -s /bin/bash /bin/sh

if [ -f /usr/bin/python ]; then
sudo rm /usr/bin/python
fi
sudo ln -s /usr/bin/python3 /usr/bin/python

sudo pip3 install setuptools kconfiglib pycryptodome ecdsa

sudo pip3 install six

# arg1=download URL; arg2=sha256 checksum URL
# ret downloaded(0), already exist checksum right(1), download fialed(3)
function DownloadAndCheck() {
checkSumFile=`basename $2`
downloadFile=`basename $1`
echo "downloadFile=$downloadFile"
echo "checksumFile=$checkSumFile"
if [ -f $downloadFile ]; then
curl $2 > $checkSumFile
#echo " $downloadFile" >> $checkSumFile
checkSum=`cat $checkSumFile`" $downloadFile"
echo $checkSum
echo $checkSum | sha256sum -c --status
if [ $? -eq 0 ]; then
return 1
else
rm $downloadFile
fi
fi

wget $1
sha256sum -c --status $checkSumFile
if [ $? -eq 0 ]; then
return 0
else
return 3
fi
}

DownloadAndCheck "https://repo.huaweicloud.com/harmonyos/compiler/gn/1717/linux/gn-linux-x86-1717.tar.gz" "https://repo.huaweicloud.com/harmonyos/compiler/gn/1717/linux/gn-linux-x86-1717.tar.gz.sha256"
mkdir -p ~/gn
tar -xvf gn-linux-x86-1717.tar.gz -C ~/gn/

DownloadAndCheck "https://repo.huaweicloud.com/harmonyos/compiler/ninja/1.9.0/linux/ninja.1.9.0.tar" "https://repo.huaweicloud.com/harmonyos/compiler/ninja/1.9.0/linux/ninja.1.9.0.tar.sha256"
tar -xvf ninja.1.9.0.tar -C ~/

if [ -f hapsigntoolv2.jar ]; then
rm hapsigntoolv2.jar
fi
wget https://repo.huaweicloud.com/harmonyos/develop_tools/hapsigntoolv2.jar
mkdir -p developtools
mv hapsigntoolv2.jar developtools/hapsigntoolv2.jar

DownloadAndCheck "https://repo.huaweicloud.com/harmonyos/compiler/clang/10.0.1-53907/linux/llvm.tar.gz" "https://repo.huaweicloud.com/harmonyos/compiler/clang/10.0.1-53907/linux/llvm.tar.gz.sha256"
tar -xvf llvm.tar.gz -C ~/

DownloadAndCheck "https://repo.huaweicloud.com/harmonyos/compiler/hc-gen/0.65/linux/hc-gen-0.65-linux.tar" "https://repo.huaweicloud.com/harmonyos/compiler/hc-gen/0.65/linux/hc-gen-0.65-linux.tar.sha256"
tar -xvf hc-gen-0.65-linux.tar -C ~/

echo "export PATH=~/gn:\$PATH" >> ~/.bashrc
echo "export PATH=~/ninja:\$PATH" >> ~/.bashrc
echo "export PATH=~/llvm/bin:\$PATH" >> ~/.bashrc
echo "export PATH=~/hc-gen:\$PATH" >> ~/.bashrc
echo "export PATH=~/llvm/bin:\$PATH" >> ~/.bashrc
echo "export PATH=~/developtools:\$PATH" >> ~/.bashrc
echo "export PATH=~/.local/bin:\$PATH" >> ~/.bashrc
source ~/.bashrc

if [ -f repo-py3 ]; then
rm repo-py3
fi
wget https://gitee.com/oschina/repo/raw/fork_flow/repo-py3
sudo mv repo-py3 /usr/local/bin/repo

sudo chmod a+x /usr/local/bin/repo
sudo pip3 install -i https://pypi.tuna.tsinghua.edu.cn/simple requests

git config --global user.name "YOUR_NAME"
git config --global user.email "$YOUR_EMAIL"
git config --global credential.helper store

if [ ! -f ~/.ssh/id_rsa.pub ]; then
ssh-keygen -t rsa -C "$YOUR_EMAIL"
fi

echo "Set the following PublicKey to gitee and press enter to continue"
cat ~/.ssh/id_rsa.pub
read READY
echo "Checking PublicKey..."
ssh -T git@gitee.com

五、映射网络驱动器

第一步,在终端执行ifconfig,查看虚拟ip地址。如图所示

env10.png

第二步,打开我的电脑,点击映射网络驱动器如图所示。

env11.png

第三步,在图中输入,\填入网址\samba用户名,勾选使用其他凭据连接。连接密码为自己设置的samba密码。

env12.png

第四步,建立samba映射成功

env13.png

六、恭喜您 下载、编译OpenHarmony代码环境配置完成!

至此,下载OpenHarmony代码、编译的环境配置完成,万事俱备只欠“下载代码”,不要停,加油!

无用

©著作权归作者所有,转载或内容合作请联系作者

您尚未登录,无法参与评论,登录后可以:
参与开源共建问题交流
认同或收藏高质量问答
获取积分成为开源共建先驱

Copyright   ©2023  OpenHarmony开发者论坛  京ICP备2020036654号-3 |技术支持 Discuz!

返回顶部