Synopsys全套docker镜像使用指南
欢迎关注公众号 摸鱼范式
前言
本教程通过win10下的docker实现,过程简单,不需要自己进行破解,同时是通过wsl方式实现,比虚拟机效率会更加高一些。
镜像是由网友制作的,eetop链接为:http://bbs.eetop.cn/thread-883833-1-1.html
仅供个人学习使用
win10下安装docker
在官网找到win10的docker安装包,进行安装
下载稳定版即可
使用前要安装wsl2,作为docker在win10下的后端支持
下载好以后直接双击安装即可
docker配置
在拉取镜像之前,先为docker设置镜像加速器,推荐阿里云的docker镜像加速服务
注册以后,进入控制台,容器镜像服务->镜像加速器
然后打开docker的设置界面,Docker Engine,将刚刚的链接复制到下面
应用并重启即可。
默认的docker的目录是在c盘下的,镜像将来会占用c盘空间,接下来移动docker的目录
首先关闭docker,然后创建一个目录D:\SoftwareData\wsl\docker-desktop-data
打开cmd,wsl -l -v
可以看到由有两个docker,我们只需要移动第二个就可以了
依次执行,
wsl --shutdown
wsl --export docker-desktop-data D:\SoftwareData\wsl\docker-desktop-data\docker-desktop-data.tar
检查以下目标目录有没有生成对应的文件docker-desktop-data.tar
wsl --unregister docker-desktop-data
wsl --import docker-desktop-data D:\SoftwareData\wsl\docker-desktop-data\ D:\SoftwareData\wsl\docker-desktop-data\docker-desktop-data.tar --version 2
移动完成
启动docker容器
通过开始菜单启动docker以后,打开cmd,拉取镜像docker pull phyzli/ubuntu18.04_xfce4_vnc4server_synopsys2016
大概有十几G,耐心等待。
镜像拉取完毕以后,启动镜像docker run -it -p 5902:5902 -p 1234:22 --hostname lizhen --mac-address 02:42:ac:11:00:02 -v //d/mydata:/mnt/mydata phyzli/ubuntu18.04_xfce4_vnc4server_synopsys2016
-p 5902:5902
是进行端口映射,这个端口是用来VNC连接的,后面-p 1234:22,是用来ssh连接的,--hostname lizhen --mac-address 02:42:ac:11:00:02
是在配置主机名和mac地址,和license绑定的,不能修改。-v //d/mydata:/mnt/mydata
是将win10下的目录//d/mydata
挂载到容器的/mnt/mydata
上,便于数据交换。
使用ssh连接的方式是因为当前存在一些bug,
docker exec -it ee bash
方式进入容器的话,编译会出现错误,通过ssh则不会出现问题。
进入到容器内部以后就可以使用了,每次进入都需要使用命令lmgrd
激活license
旧版本的镜像没有设置开机启动license,现在新版本的镜像不需要每次进入都使用
lmgrd
激活license了,可以省略这一步
测试一下vcs是否正常,进入到我们挂载的目录mnt/mydata
,下面是tb.sv
的内容
module tb ();
initial begin
$display("hello vcs");
end
endmodule
vcs tb.sv
进行编译,然后./simv
进行仿真
接下来试一下vnc远程桌面,通过命令vncserver -geometry 1920x1080 :2
在容器内启动vnc
win10中打开vncviewer,配置连接,地址是127.0.0.1:5902
进行连接,连接密码为zhenchen
进入图形化界面
下面试一下vcs和verdi的联合仿真,同样还是前面的tb.sv
vcs tb.sv -debug_all -lca -kdb
./simv -gui=verdi
接下来测试ssh连接,首先要修改一下容器的root密码,因为ssh并没开放root密码为空登录,默认的root密码是空的。通过命令passwd
即可修改密码。
然后再开一个命令行,通过命令 ssh -p 1234 root@127.0.0.1
就能够通过ssh远程访问
其他
进入容器后,直接exit
会退出容器,如果在启动容器时加上-d
,容器会在后台继续运行
通过docker ps -a
可以查看容器的状态
如果想要再启动容器,可以通过docker start ee
启动容器,ee
是容器ID的前两位,不用全部打完也可以
启动容器后如果要进入容器,通过指令docker exec -it ee bash
就能进入了
删除容器可以通过指令docker rm -f ee
,删除容器不会把刚刚挂载的文件夹删除,不用担心。
追加
原作者还提供了另外的几个镜像
phyzli/centos8_xfce4_tigervnc_hspice2010,2060年到期,需要lmgrd;
phyzli/centos8_xfce4_tigervnc_virtuosoic617_mmsim15_calibre2015,virtuoso永久,calibre2015 4963年到期,不需要挂载license;
这两个镜像的hostname和mac地址都和synopsys2016一致。