梁嗖嗖这两天拿到了新玩具

本文的设备情况:

本文默认读者已经根据500小站用户指南,完成设备上电等前置操作:https://support.huawei.com/enterprise/zh/doc/EDOC1100133176/c6355e39

小站是华为欧拉linux系统(aarch64架构),Ascend310芯片,本文的500完全隔绝外网 (正常的500可以连接外网),也没有apt-get install等方式安装软件,但是小站系统自带docker软件,仅用于模型边缘部署。

uname -a 查看系统架构信息:


由于a500的网络原因,我们用身边的一Jetson nano2gb进行docker 镜像部署,好处在于都是aarch64 架构,感觉构建镜像时会更顺利。用其他linux设备是一样的。

DockerFile基于ubuntu18.04进行构建,包括安装atlas500部署所用的Ascend-cann-nnrt_5.0.4.alpha002_linux-aarch64.run、以及后台AI引擎所需的python依赖、redis、linux所需的必要软件。

在此解释一下CANN分为cann-toolkit 和 cann-nnrt ;区别大致是toolkit包更完整,包含开发,推理训练都可以;nnrt是离线推理引擎包,较为轻量,包含开发、推理应用。像模型转换操作就只能用cann-toolkit包。因为我们只在500部署,所以选用nnrt包。

- Dockerfile文件作为参考

基于sample样例进行开发时,要看清楚软件版本,比如python版本

其中的MindX SDK安装是可选操作,后续的文章没有用到。

其中,以root用户登录小站,执行id HwHiAiUser命令查询并记录宿主机上HwHiAiUser用户的UID和GID。
 

为在容器内创建HwHiAiUser用户。gid、uid为宿主机上HwHiAiUser用户的UID和GID,容器内的HwHiAiUser用户的UID和GID需要和宿主机保持一致。

id HwHiAiUser


由于内网部署网络的限制,同时为软件环境修改方便,本文借助其他外网设备,通过DockerFile方式构建docker镜像,再把打包好的镜像文件上传至500小站使用。由于小站是aarch64架构,所用的apt源和开发软件的架构也要是aarch64架构,我们镜像构建和后续的模型转换在另一台可连接外网的atlas200 DK(arrch64)设备上操作。

由于设备不在身边,完全内网环境,通过公网ip远程登录。我们在构建docker时,需要了解后续的开发方式,准备所需软件环境。

经过研究文档发现,在昇腾设备上开发主要有两种方式:

使用MindX SDK推理,MindX SDK是一种插件化编程方式,我理解是一个简化的推理SDK,少量代码开发,拼接几个预定义好的插件就可以实现应用开发,尝试过但遇到一些程序崩溃问题,同时觉得过于模板化,自主性不强,没有使用。
基于ACL架构进行开发,这种算是采用ascend的API进行自主开发编译运行,并不需要从0开发,昇腾的样例仓中有很多参考项目,可以基于昇腾的sample开发:https://gitee.com/ascend/samples,同时参考Ascend的开发工具包 CANN推理的API文档,

镜像构建前置操作

拿到atlas500,可以ssh远程登录后,进入的初始系统是类似启动项,还不是Euler系统

登录Euler系统之前,我们要在IES界面做一些操作:

ssh远程登录a500后,在IES:/ -> 界面,首先输入 sftp enable,终端返回 set enable success,即可开放atlas500的 /tmp 目录,进行远程文件传输。

但/tmp目录仅有2G空间。并且是临时目录,固件升级等操作会将该目录清空,可仅用于文件传输目录,不可长时间存放文件。博主曾经将代码放到该目录下用Xftp打开文件编辑代码,这样很危险,/tmp被清空没有备份就凉凉了。

重置会话超时时间,否则超时后,ssh会话会自动关闭,远程终端中断。

在IES界面输入timeout 0 ,终端返回set success;然后输入develop (开发者模式),进入欧拉系统。再输入TMOUT=0:

Euler:~ # TMOUT=0

其中,我的driver固件版本为21.0.4,CANN版本必须和固件版本配套,否则会遇到很多不可预料的问题。关于版本不匹配导致的问题见issues:https://gitee.com/ascend/samples/issues/I532OI?from=project-issue

下载固件时,会有版本的对应关系:https://www.hiascend.com/hardware/firmware-drivers?tag=community

比如下图:CANN的5.0.4版本,必须对应21.0.4的固件版本。但我在使用时发现,社区版的固件更新是滞后的。导致一直在使用低版本的固件,出现很多玄学问题,最后版本匹配后就解决了。

固件升级,选择智能边缘管理系统升级最方便,参考文档:(https://support.huawei.com/enterprise/zh/doc/EDOC1100133173/dede8113)

在构建docker 镜像前我们要确定CANN的版本,本文选用 昇腾CANN社区版(5.0.4.alpha002),后续的操作应严格按照CANN对应的文档来,CANN文档分为训练和推理,请移步: 昇腾CANN社区版(5.0.4.alpha002)(训练)昇腾CANN社区版(5.0.4.alpha002)(推理)  


mxManufacture 社区版历史版本-昇腾社区 (hiascend.com)

CANN社区版历史版本-昇腾社区 (hiascend.com)

固件与驱动-昇腾社区 (hiascend.com)


freenas centos 搭建 freenas安装docker_linux

freenas centos 搭建 freenas安装docker_linux_02

freenas centos 搭建 freenas安装docker_freenas centos 搭建_03

failed to activate service 'org.freedesktop.systemd1' timed out

重启设备最直接 

docker 镜像构建过程,也可以参考官方文档https://support.huawei.com/enterprise/zh/doc/EDOC1100133176/63895f14

 在jetson nano2gb和虚拟机或其他linux设备均可构建镜像:

本章节用了目前最新的 CANN版本20220429的

5.1.RC2.alpha0022022/04/29

sudo docker build -t atlas500_last:v5 --build-arg NNRT_PKG=Ascend-cann-nnrt_5.1.RC2.alpha002_linux-aarch64.run --build-arg SDK_PKG=Ascend-mindxsdk-mxmanufacture_2.0.1_linux-aarch64.run .
Step 28/31 : ARG SDK_PKG
 ---> Running in 5ca9aa4350b1
Removing intermediate container 5ca9aa4350b1
 ---> a30dcf41e28d
Step 29/31 : WORKDIR /root
 ---> Running in 3e56bbd34c65
Removing intermediate container 3e56bbd34c65
 ---> 8aa4908d80f3
Step 30/31 : COPY $SDK_PKG .
 ---> 61ff505f00f6
Step 31/31 : RUN chmod +x ${SDK_PKG} &&	./${SDK_PKG} --quiet --install &&	rm ${SDK_PKG} &&	/bin/bash -c "source ~/.bashrc"
 ---> Running in b62cdc09673c
MS_check_platform ./Ascend-mindxsdk-mxmanufacture_2.0.1_linux-aarch64.run aarch64 ./Ascend-mindxsdk-mxmanufacture_2.0.1_linux-aarch64.run
Installing the compiler version of devtoolset-7 ...
valid acl path(/usr/local/Ascend/nnrt/latest/acllib/lib64), continue the installation...
Removing intermediate container b62cdc09673c
 ---> 80bc0532963b
Successfully built 80bc0532963b
Successfully tagged atlas500_last:v5

其中,-t指明镜像名和版本号;–build-arg NNRT_PKG=“输入cann-nnrt包的路径” ;–build-arg SDK_PKG= “输入MindX SDK的路径” (可选)

构建镜像结束:

docker images # 查看镜像

sudo docker images REPOSITORY TAG IMAGE ID CREATED SIZE atlas500_last v5 80bc0532963b 46 hours ago 2.11GB <none> <none> 46c328d1107d 2 days ago 963MB <none> <none> a1109cfd5ace 2 days ago 963MB <none> <none> 4dab7f42cd46 2 days ago 963MB <none> <none> d56976a41944 2 days ago 858MB <none> <none> 1e1c5837f43d 2 days ago 858MB <none> <none> 69d42aefafe5 2 days ago 852MB <none> <none> a65f64a1d1f8 2 days ago 852MB ubuntu 18.04 cc6f13ca5102 3 weeks ago 56.7MB mynode latest a95f5c09255a 5 weeks ago 941MB <none> <none> c9c4ded471bc 5 weeks ago 941MB komavideo/mynode v01 84d0ad3355e9 5 weeks ago 843MB node latest 6c8ffad9dee1 5 weeks ago 941MB liang v1.0 57d122d6ddd6 6 weeks ago 22.8MB nginx 1.21.6-alpine 674e6760e55a 6 weeks ago 22MB dreamacro/clash latest 9141f5511311 2 months ago 22.8MB nvcr.io/nvidia/dli/dli-nano-deepstream v2.0.0-DS6.0.1zh 546f93b57c99 2 months ago 2.22GB nvcr.io/nvidia/dli/dli-nano-deepstream v2.0.0-DS6.0.1 eb0e1e157f1d 2 months ago 2.22GB nvcr.io/nvidia/dli/dli-nano-ai v2.0.1-r32.6.1zh 1b81ef235451 9 months ago 3.38GB nvcr.io/nvidia/dli/dli-nano-ai v2.0.1-r32.6.1 a4e89dcd35e9 9 months ago 3.38GB nvcr.io/nvidia/l4t-ml r32.6.1-py3 4818848f7fee 9 months ago 5GB nvcr.io/nvidia/l4t-base r32.6.1 1735192d3d51 10 months ago 636MB python 3.8.10-alpine3.12 55a886bec186 11 months ago 42.8MB nvcr.io/nvidia/dli/dli-nano-ai v2.0.1-r32.5.0 bc9051ff252d 17 months ago 3.73GB node 8.16.1 6ff56af4db98 2 years ago 843MB jitteam/devicequery latest eba22039865c 2 years ago 1.57GB


将镜像文件导出,通过/tmp目录上传至atlas500 可以看到我的镜像已经很大了,我们在dockerfile中构建时,可以将不用的软件包删除,比如MindX sdk 我这里是用的前面我的文章上传的,我的镜像是有mxManufacture的是1.9g,刚好不够上传,上传文章看这个 将这个镜像保存下来打包。 docker save 80bc0532963b > atlas500_last.tar

nfs开发上传文件

(38条消息) Atlas500小站和Jetson nano使用nfs开发_无证驾驶梁嗖嗖的博客-CSDN博客

  • atlas500运行镜像生成容器

sudo docker run --privileged --network=host --device=/dev/davinci0 --device=/dev/davinci_manager --device=/dev/hisi_hdc --device /dev/devmm_svm -v /usr/local/bin/npu-smi:/usr/local/bin/npu-smi -v /home/data/miniD/driver/lib64:/home/data/miniD/driver/lib64 -v /run/board_cfg.ini:/run/board_cfg.ini -it atlas500_last:v5 /bin/bash

其中,–privileged开启特权模式,容器才能调用宿主机的npu芯片,即device。

–network=host 开启宿主机的网络映射,容器才能和宿主机一样访问网络。

-it atlas500_last:v5,指明容器的名称: 版本号


Authorized users only. All activities may be monitored and reported.
Last login: Thu May 19 21:19:02 2022 from 192.168.2.134
IES:/->develop
input root passwd
Password:
Last login: Thu May 19 21:21:39 UTC 2022 on pts/0
-bash: /usr/local/Ascend/nnrt/set_env.sh: No such file or directory
Euler:~ # cd /opt/middleware/MindXOM/bin/
Euler:/opt/middleware/MindXOM/bin # LS
-bash: LS: command not found
Euler:/opt/middleware/MindXOM/bin # ls
ibma_edge_log_check.sh  ief_log_tar_save.sh  import_cert  inotifywait  inotifywatch  log_file_rotate.sh  log_tar_save.sh  mount_white_path  prepare_nginx
Euler:/opt/middleware/MindXOM/bin # timed out waiting for input: auto-logout
IES:/->./mount_white_path display
        COMMAND NOT SUPPORTED
IES:/->develop
input root passwd
Password:
Last login: Thu May 19 22:08:44 UTC 2022 on pts/0
-bash: /usr/local/Ascend/nnrt/set_env.sh: No such file or directory
Euler:~ # cd /opt/middleware/MindXOM
MindXOM/        MindXOMPackage/
Euler:~ # cd /opt/middleware/MindXOM/bin/
Euler:/opt/middleware/MindXOM/bin # ls
ibma_edge_log_check.sh  ief_log_tar_save.sh  import_cert  inotifywait  inotifywatch  log_file_rotate.sh  log_tar_save.sh  mount_white_path  prepare_nginx
Euler:/opt/middleware/MindXOM/bin # ./mount_white_path display
/opt/mount/
Euler:/opt/middleware/MindXOM/bin # du -sh /opt/
ascend/         containerd/     edged/          edge-installer/ edge-register/  FD/             IEF/            local/          lost+found/     middleware/     p7.log
Euler:/opt/middleware/MindXOM/bin # du -sh /opt/
ascend/         containerd/     edged/          edge-installer/ edge-register/  FD/             IEF/            local/          lost+found/     middleware/     p7.log
Euler:/opt/middleware/MindXOM/bin # du -sh /opt/mount/
du: cannot access '/opt/mount/': No such file or directory
Euler:/opt/middleware/MindXOM/bin # ./mount_white_path add /home/test/
/home/test/ added successfully
Euler:/opt/middleware/MindXOM/bin # ./mount_white_path check /home/test/
/home/test/ exists in the list
Euler:/opt/middleware/MindXOM/bin # ./mount_white_path add /var/lib/docker
/var/lib/docker/ added successfully
Euler:/opt/middleware/MindXOM/bin #
  • 简单docker操作

docker ps 查看容器:

如果没有刚生成的容器,可能是挂起了, docker ps --all查看所有容器。

docker start containerID 即可启动容器

docker exec -it 0665 /bin/bash 进入容器

进入容器后,检查输入npu-smi info 出现芯片信息,检查相关软件环境,即安装成功。

进行推理之前,需要到容器中CANN的安装目录下,激活环境

我的路径在:

cd /usr/local/Ascend/nnrt/ source set_env.sh

下面截图是操作流程,每个人操作肯定都会出现一点差别,有错误就百度就好了谢谢,我这里算是搭建完成了

Euler:/var/lib/docker # sudo docker load --input atlas500_last.tar
cf1e6f9bc415: Loading layer [==================================================>]  58.92MB/58.92MB
83c55ccfd1dd: Loading layer [==================================================>]  5.632kB/5.632kB
c81cba95da2c: Loading layer [==================================================>]  624.6MB/624.6MB
a6de161bc9b1: Loading layer [==================================================>]  503.3kB/503.3kB
ea2516965b6a: Loading layer [==================================================>]  2.048kB/2.048kB
05cdfe7f27a2: Loading layer [==================================================>]  39.43MB/39.43MB
7b960d531595: Loading layer [==================================================>]  114.9MB/114.9MB
af8b880b1034: Loading layer [==================================================>]   35.7MB/35.7MB
4e54d9e901b7: Loading layer [==================================================>]     64kB/64kB
eb58e9af3469: Loading layer [==================================================>]  106.3MB/106.3MB
c96a6a42ec28: Loading layer [==================================================>]   2.56kB/2.56kB
d2ae4882554d: Loading layer [==================================================>]  54.14MB/54.14MB
642ee8462f24: Loading layer [==================================================>]  186.1MB/186.1MB
a74fd2a3cb37: Loading layer [==================================================>]  202.2MB/202.2MB
222a419a3b12: Loading layer [==================================================>]  367.9MB/367.9MB
fb8b229ff52c: Loading layer [==================================================>]  66.66MB/66.66MB
82b75569fe7c: Loading layer [==================================================>]  289.2MB/289.2MB
Loaded image ID: sha256:80bc0532963b2dcafc90838e64f421eccf2688fd6b9eabfdea55d69c189af9b9
Euler:/var/lib/docker # ls
123318e6f14a9bac417b58a582770a9a13d2d03cb29d46c4caab1fb1558a3767       buildkit                                                          lost+found
1fd354bca2188d778b92086dd131cdbf3b046dbbfa51fd2f2adbac0e0c017224       c35541413eda38b07261fcc12a3cf6eb30ae4f0e5c25361df2907850bf9aaad0  manifest.json
2c7a0cee8a30ec04ed7728c27a1543212178b75cdc734dcbf1c80abefdc2533b       c429f88e9e0c371dce0434a7d0acca44cabba39257e3b8234d0ef5b72b9f1e2e  modelfile
38a11c69bd4eec6e4c4167ae24d760c4295987b30d55cc869fc4329b3de1ce42       c9253a3158e099948f4fd2ce7658a0b65cf107a6915fdd54822a0fafdced5d24  model_file_download
6b2e4891ee2a9ae65412b1909384ed1f7af59fe3c750ff1c63df6eebfd0f177a       containerd                                                        network
80bc0532963b2dcafc90838e64f421eccf2688fd6b9eabfdea55d69c189af9b9.json  containers                                                        overlay2
86c724ac37aa88d2493541c702f431b9a0c0250266c2a289baae352240290347       d45c5b1343e28c35a1720ba99add48ea6aac63928039e9f0a9206bb79e17ae33  p8.log
8d2be0e13c1d1c06e0d04a1193022e3ce66331e5e016c0f619af74eab1dc8235       d51a0020677fc6b5bc1ea82d00fa274c506cee52de41cbe91bd55da6d26cac7e  plugins
92135f2ca611ce11eed8007194af9429891d2ad56e1e04b41a59794e6508f4a6       e08b7dc0536c0cd7611a4e0eb29fab49b151b97265674963dca596345991848c  runtimes
Ascend-cann-nnrt_5.1.RC2.alpha002_linux-aarch64.run                    e80c4ede417a3a31b02f7b88dff3e2c260f3cdd547975d056d6835437e77e87d  samples-master
Ascend-cann-toolkit_5.1.RC2.alpha002_linux-aarch64.run                 e82d00408b2ec30c56845a3b96b55e79c6578449878943664c3b7708e10f20d6  swarm
atlas500_last.tar                                                      f5ec45b50337ab3772a62ce12b30fa8e92b2caecdbe86333944a94956c9ab174  tmp
attach_file_download                                                   hooks                                                             trust
builder                                                                image                                                             volumes
Euler:/var/lib/docker # sudo docker images
REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE
<none>              <none>              80bc0532963b        27 hours ago        2.11GB
<none>              <none>              20908a61c3bf        21 months ago       1.95MB
k8s.gcr.io/pause    latest              6b8dc5dab442        21 months ago       1.59MB
Euler:/var/lib/docker # docker run --privileged --network=host --device=/dev/davinci0 --device=/dev/davinci_manager --device=/dev/hisi_hdc --device /dev/devmm_svm -v /usr/local/bin/npu-smi:/usr/local/bin/npu-smi -v /home/data/miniD/driver/lib64:/home/data/miniD/driver/lib64 -v /run/board_cfg.ini:/run/board_cfg.ini -it atlas500_last:v5 /bin/bash
Unable to find image 'atlas500_last:v5' locally
docker: Error response from daemon: Get "https://registry-1.docker.io/v2/": dial tcp: lookup registry-1.docker.io on [::1]:53: read udp [::1]:37650->[::1]:53: read: connection refused.
See 'docker run --help'.
Euler:/var/lib/docker #
Euler:/var/lib/docker # ————————————————
-bash: ————————————————: command not found
Euler:/var/lib/docker # 
shine: command not found
Euler:/var/lib/docker # docker run --privileged --network=host --device=/dev/davinci0 --device=/dev/davinci_manager --device=/dev/hisi_hdc --device /dev/devmm_svm -v /usr/local/bin/npu-smi:/usr/local/bin/npu-smi -v /home/data/miniD/driver/lib64:/home/data/miniD/driver/lib64 -v /run/board_cfg.ini:/run/board_cfg.ini -it 80bc0532963b /bin/bash
root@Euler:~# ls
mxManufacture  mxManufacture-2.0.1  redis
root@Euler:~# cd mxManufacture
root@Euler:~/mxManufacture# ls
bin  config  filelist.txt  include  lib  opensource  python  samples  toolkit  version.info
root@Euler:~/mxManufacture# cd ..
root@Euler:~# cd
.bashrc              .cache/              .local/              .profile             mxManufacture/       mxManufacture-2.0.1/ redis/
root@Euler:~# ls
mxManufacture  mxManufacture-2.0.1  redis
root@Euler:~# cd redis/
root@Euler:~/redis# ls
redis-5.0.5  redis-5.0.5.tar.gz
root@Euler:~/redis# cd redis-5.0.5
root@Euler:~/redis/redis-5.0.5# ls
00-RELEASENOTES  CONTRIBUTING  INSTALL    Makefile   deps        runtest          runtest-moduleapi  sentinel.conf  tests
BUGS             COPYING       MANIFESTO  README.md  redis.conf  runtest-cluster  runtest-sentinel   src            utils
root@Euler:~/redis/redis-5.0.5# uname -a
Linux Euler 4.19.90-vhulk2111.1.0.h963.eulerosv2r10.aarch64 #1 SMP Sat Dec 25 05:09:23 UTC 2021 aarch64 aarch64 aarch64 GNU/Linux
root@Euler:~/redis/redis-5.0.5# cd ..
root@Euler:~/redis# ls
redis-5.0.5  redis-5.0.5.tar.gz
root@Euler:~/redis# cd ..
root@Euler:~# ls
mxManufacture  mxManufacture-2.0.1  redis
root@Euler:~# ./mxManufacture
bash: ./mxManufacture: Is a directory
root@Euler:~# cd /etc/
root@Euler:/etc# ls
Ascend                  cron.daily      dpkg           gshadow      issue          login.defs     mtab           passwd-    rc1.d        rpc            skel         systemd
X11                     cron.hourly     emacs          gshadow-     issue.net      logrotate.d    network        perl       rc2.d        securetty      ssl          terminfo
adduser.conf            cron.monthly    environment    gss          kernel         lsb-release    networks       pm         rc3.d        security       subgid       ucf.conf
alternatives            cron.weekly     ffserver.conf  host.conf    ld.so.cache    machine-id     nsswitch.conf  profile    rc4.d        selinux        subgid-      update-motd.d
apt                     crontab         fonts          hostname     ld.so.conf     magic          openal         profile.d  rc5.d        sensors.d      subuid       vdpau_wrapper.cfg
bash.bashrc             dbus-1          fstab          hosts        ld.so.conf.d   magic.mime     opt            protocols  rc6.d        sensors3.conf  subuid-      vim
bindresvport.blacklist  debconf.conf    gai.conf       hosts.allow  ldap           mailcap        os-release     pulse      rcS.d        services       sudoers      wgetrc
ca-certificates         debian_version  glvnd          hosts.deny   legal          mailcap.order  pam.conf       python3    redis.conf   shadow         sudoers.d    xdg
ca-certificates.conf    default         group          init.d       libaudit.conf  mime.types     pam.d          python3.6  resolv.conf  shadow-        sysctl.conf
cron.d                  deluser.conf    group-         inputrc      logcheck       mke2fs.conf    passwd         rc0.d      rmt          shells         sysctl.d
root@Euler:/etc# cd Ascend/
root@Euler:/etc/Ascend# ls
ascend_cann_install.info
root@Euler:/etc/Ascend# cd ..
root@Euler:/etc# cd ..
root@Euler:/# ls
bin  boot  dev  etc  home  lib  media  mnt  opt  proc  root  run  sbin  srv  sys  tmp  usr  var
root@Euler:/# cd home/
root@Euler:/home# ls
HwHiAiUser  data  ljx
root@Euler:/home# cd ljx/
root@Euler:/home/ljx# ls
test
root@Euler:/home/ljx# cd test/
root@Euler:/home/ljx/test# ls
packages
root@Euler:/home/ljx/test# cd packages/
root@Euler:/home/ljx/test/packages# ls
requests-offline
root@Euler:/home/ljx/test/packages# cd requests-offline/
root@Euler:/home/ljx/test/packages/requests-offline# ls
 certifi-2019.9.11-py2.py3-none-any.whl   idna-2.8-py2.py3-none-any.whl  'python3.7.4 requests2.22.0.zip'   requests-2.22.0-py2.py3-none-any.whl
 chardet-3.0.4-py2.py3-none-any.whl       python-3.7.4-amd64.exe          requests-2.22.0                   urllib3-1.25.6-py2.py3-none-any.whl
root@Euler:/home/ljx/test/packages/requests-offline# cd ..
root@Euler:/home/ljx/test/packages# ls
requests-offline
root@Euler:/home/ljx/test/packages# ifc
bash: ifc: command not found
root@Euler:/home/ljx/test/packages# sudo apt-get update
Err:1 http://ports.ubuntu.com/ubuntu-ports bionic InRelease
  Temporary failure resolving 'ports.ubuntu.com'
Err:2 http://ports.ubuntu.com/ubuntu-ports bionic-updates InRelease
  Temporary failure resolving 'ports.ubuntu.com'
Err:3 http://ports.ubuntu.com/ubuntu-ports bionic-backports InRelease
  Temporary failure resolving 'ports.ubuntu.com'
Err:4 http://ports.ubuntu.com/ubuntu-ports bionic-security InRelease
  Temporary failure resolving 'ports.ubuntu.com'
Reading package lists... Done
W: Failed to fetch http://ports.ubuntu.com/ubuntu-ports/dists/bionic/InRelease  Temporary failure resolving 'ports.ubuntu.com'
W: Failed to fetch http://ports.ubuntu.com/ubuntu-ports/dists/bionic-updates/InRelease  Temporary failure resolving 'ports.ubuntu.com'
W: Failed to fetch http://ports.ubuntu.com/ubuntu-ports/dists/bionic-backports/InRelease  Temporary failure resolving 'ports.ubuntu.com'
W: Failed to fetch http://ports.ubuntu.com/ubuntu-ports/dists/bionic-security/InRelease  Temporary failure resolving 'ports.ubuntu.com'
W: Some index files failed to download. They have been ignored, or old ones used instead.
root@Euler:/home/ljx/test/packages# cd ..
root@Euler:/home/ljx/test# cd ..
root@Euler:/home/ljx# cd ..
root@Euler:/home# cd /etc/apt/sources.list
bash: cd: /etc/apt/sources.list: Not a directory
root@Euler:/home# sudo vi /etc/apt/sources.list
root@Euler:/home# python3
Python 3.6.9 (default, Mar 15 2022, 13:55:28)
[GCC 8.4.0] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> import ctl
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
ModuleNotFoundError: No module named 'ctl'
>>> import acl
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
ModuleNotFoundError: No module named 'acl'
>>> ls
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
NameError: name 'ls' is not defined
>>>
KeyboardInterrupt
>>>
root@Euler:/home#
root@Euler:/home# cd /usr/local/Ascend/nnrt/
root@Euler:/usr/local/Ascend/nnrt# ls
5.1  5.1.RC2.alpha002  latest  set_env.sh
root@Euler:/usr/local/Ascend/nnrt# ./set_env.sh
root@Euler:/usr/local/Ascend/nnrt# ls
5.1  5.1.RC2.alpha002  latest  set_env.sh
root@Euler:/usr/local/Ascend/nnrt# python3
Python 3.6.9 (default, Mar 15 2022, 13:55:28)
[GCC 8.4.0] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> import acl
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
ModuleNotFoundError: No module named 'acl'
>>>
root@Euler:/usr/local/Ascend/nnrt# source set_env.sh
root@Euler:/usr/local/Ascend/nnrt# python3
Python 3.6.9 (default, Mar 15 2022, 13:55:28)
[GCC 8.4.0] on linux
Type "help", "copyright", "credits" or "license" for more information.
>>> import acl
>>> acl.init()
0
>>>
>>>
>>>
>>>
>>>
>>>
>>>
>>>