基于Linux系统WINE虚拟机技术的研究

简介:







WINE32位代码,Linux中的stdcall(gcc)支持Windows常规调用,因此可以直接替换WINE处理器中的地址导入Win32代码,但对于16位模块还需要添加thunk进行地址等方面的转换。
三、 WINE 启动分析
  由于Linux早期版本提供的线程API不够强大,不足以实现Windows API线程部分,WINE利用Linux kernel thread重新构建了Windows线程API函数,该部分在WINE中称为WINE-kthread。随着Linux的发展,Linux后来的版本中出现了功能强大的NPTL线程子系统,WINE利用此系统提供的API函数粘合了Windows线程API函数,此部分称为WINE-pthreadWINE在启动前首先检查用户使用的线程模式并执行由WINE-pthreadWINE-kthread实现的WINE preloader。它是一个没有main主函数的ELF文件,用于在新建立的WINE进程中设置Win32类型的进程地址空间布局后转入WINEmain函数,WINE被启动。Preloader通过这种方式传递一些必要信息到libwineWINE的动态库)中,并调用函数Wine-init进行debug功能和地址空间方面的处理。以后顺次执行:
1-WINE-process-init建立Win32程序运行所必需的结构,如PEBTEB、进程堆以及与WINE server的连接等。
2-Wine-kernel-init依次执行:从WINE server获得新进程启动时必需的信息;初始化新进程的的注册以及其它相关部分;确定被加载文件的类型以后该应用程序被载入内存。
3.新载入Windows程序运行的开始。首先,start-process建立SHE,调用NtdllLdr-Initializer Thuck执行进程初始化的其他部分,如进行重定位以及调用DLL的构造函数等。最后,执行转入被载入应用程序的入口点,应用程序开始执行,WINE提供的API就可以被正确地调用了,随后当执行从应用程序返回时,调用ExitProcess函数结束该进程。
四、 Win32 启动分析
  从命令行启动一个WINE进程时,WIN-E首先检查操作系统使用的线程模式,启动WINE装载器。WINELinux中取得诸如运行环境、命令行参数等必要的资源的后依次执行:
1.               NTDLL.dll.soLinux的标准共享库装载器载入内存,在Linux中建立PEBTEB、进程堆以及与WINE Server的连接等。
2.               利用Windows动态装载能力加载Ke-rne132-WINE-kernel-init处理所有装载与执行的逻辑过程,包括初始化命令行参数,在文件系统中寻找相应的可执行文件。如果没有找到,WINE装载器停止装载并返回出错信息;否则,将找到的文件载入内存,建立一个堆栈供新建立的可执行文件的进程作用,堆栈大小由该文件结构中PE-header定义。
3.               Ntdll.LdrInitializeThunk执行其他部分如解析所有在可执行文件中引用的DLLTLS槽的初始化。
4.               执行转入到可执行文件的入口点,可执行文件开始运行。
如果有多个Win32程序要求运行,WINE为这些Win32程序分别建立WINE进程。这些Win32程序在各自的WINE进程中运行。(如图2所示)。
 
 
 
五、 Winelib 启动分析
Win 16
程序
Win 16
程序
WINE
VDM
Win32
程序
WINE
Process
Win32
程序
WINE
Process
 
WINE
 
SERVER
 
X 显示
 
服务器
 
 
 
 
 
 
 
 
 
 
 
 

2
Winelib(假定有一个文件example.exe)对应有两个文件:example为一个链接到WINE装载器的符号链接;example.exe.so相当于一个Linux中的动态连接库。
从命令行启动一个Winelib程序时,Linux shellexample作为一个Linux的可执行文件。由于它实际是WINE的一个装载器,所有WINE被启动并利用Linux的共享库机制加载第二个文件example.exe.soWINE根据文件的描述符确认它是一个32位模块,于是共享库被加载,再处理该可执行文件的导入节,调用全局对象的构造器,便于以后加载动态库函数,最后执行转入可执行文件的入口点,载入的文件开始运行。
六、 Win16 DOS 程序启动分析
一个Win16程序要求运行时,WINE将该程序交给虚拟DOS机(VDM)。虚拟机首先建立一个16位的运行环境,Win16程序就在该虚拟环境中运行。此后由该程序创建的子程序均在同一虚拟机实例中运行。虚拟机为16位的进程提供了诸如多任务协作,共享地址空间,管理为16位进程建立的代码段、数据段与堆栈段的选择器等功能。
DOS程序的启动与Win16的启动过程类似,对虚拟机对DOS程序还采用互斥机制保证DOS程序的运行是单线程的,如图2所示。
七、 Wine 实战
我们可以在http://fedoraproject.org/wiki/AndreasBierfert/Wine下载到针对Fedora12Wine最新版本是1.1.38 当下载到tar包后Cd到安装目录中运行wineinstall(安装释放文件)文件,之后它会运行./configure,然后显示:We need to install wine as root user, do you want us to build wine,'su root' and install Wine? Enter 'no' to continue without installing(yes/no) 我们选yes并回车如果在此处出现错误,请检查此命令的输出,如果他没有找到一些需要的包,而你又希望使用那个包提供的功能时,请安装相应的 devel 包。
如果你root用户设置了密码,还会提示你输入密码。
  待屏幕上出现:
  Installation complete for now. Good luck (this is still alpha software).
  If you have problems with WINE, please read the documentation first,
  as many kinds of potential problems are explained there.
 看到这条提示,则表示安装成功了。
 shell下运行wine,第一次运行不成功,这是正常,因为没有在/root/.wine/config文件里配置好.找到这些吧。
  [Drive C]
  "Path" = "/usr/share/win_c"
  "Type" = "hd"
  "Label" = "MS-DOS"
  "Filesystem" = "win95"
  改为:[Drive C]
  "Path" = "/winc"
  "Type" = "hd"
  "Label" = "MS-DOS"
  "Filesystem" = "win95"
  就可以了,如果你安装了simsun字体.wine默认就会找到这个字体的。
  我们在运行windows 程序时,常常会出现看不到中文的情况,那是因为在GBK GB2312 编码状态下可以输入中文,但如果没有进行默认编码设置,就无法输入中文。
通过设置locale可以解决。具体方法如下:
编辑 .bashrc 文件在该文件尾部添加如下两行:
export LANG=zh_CN.gb2312
export LC_ALL=zh_CN.2312
重新运行 bash 后敲入 locale 命令,默认的编码就会显示 GB2312
另外, 还有就是如果没有中文字体也无法显示中文,自然也就看不见汉字。
下一步该运行应用程序 了,可以通过两种方式运行:
1.自动运行
  在KDE或者GNOME的文件管理器中切换到应用程序所在目录,单击就可以打开。虽然程序运行速度十分缓慢,不过聊胜于无。
2.手工运行
  在Console模式下,键入以下命令: wine <将要运行的应用程序>
3.举个例子来说吧
  想要通过WINELinux下使用Winzip,这么做呢重新运行winesetup,在配置Windows安装路径窗口中,选择“Create a new windows directory(创建一个新的Windows安装目录)”,其它的一切都很简单,在Linux中直接运行Winzip安装文件安装Winzip然后就可以调用了。
总结
本文对在Linux系统中运行Windows程序的一种实现--WINE内核运行的机理和实例进行了详尽分析。在比较了Windows程序转移到Linux中各种技术实现及各自特点的基础上,阐述了WINE的体系结构及各部分的功能,并通过对不同类型Windows程序启动过程的分析,揭示了WINELinux中创建Win32线程/进程环境与调用动态链接库的技术。由于当前Linux平台上应用程序的类型与数目不多,大部分企业还不能确定是否应该将Windows应用程序移植到Linux系统中,更多的厂商在等待Linux系统大规模应用于桌面。将Windows应用程序移植到Linux环境中运行对于此难题的解决则是一个非常有效的方式。







 本文转自 李晨光 51CTO博客,原文链接: http://blog.51cto.com/chenguang/309639 ,如需转载请自行联系原作者

 
相关文章
|
6天前
|
Linux
Linux系统之whereis命令的基本使用
Linux系统之whereis命令的基本使用
50 23
Linux系统之whereis命令的基本使用
|
3月前
|
Linux
在 Linux 系统中,“cd”命令用于切换当前工作目录
在 Linux 系统中,“cd”命令用于切换当前工作目录。本文详细介绍了“cd”命令的基本用法和常见技巧,包括使用“.”、“..”、“~”、绝对路径和相对路径,以及快速切换到上一次工作目录等。此外,还探讨了高级技巧,如使用通配符、结合其他命令、在脚本中使用,以及实际应用案例,帮助读者提高工作效率。
194 3
|
3月前
|
监控 安全 Linux
在 Linux 系统中,网络管理是重要任务。本文介绍了常用的网络命令及其适用场景
在 Linux 系统中,网络管理是重要任务。本文介绍了常用的网络命令及其适用场景,包括 ping(测试连通性)、traceroute(跟踪路由路径)、netstat(显示网络连接信息)、nmap(网络扫描)、ifconfig 和 ip(网络接口配置)。掌握这些命令有助于高效诊断和解决网络问题,保障网络稳定运行。
143 2
|
2月前
|
存储 缓存 监控
Linux缓存管理:如何安全地清理系统缓存
在Linux系统中,内存管理至关重要。本文详细介绍了如何安全地清理系统缓存,特别是通过使用`/proc/sys/vm/drop_caches`接口。内容包括清理缓存的原因、步骤、注意事项和最佳实践,帮助你在必要时优化系统性能。
230 78
|
1月前
|
缓存 安全 Linux
Linux系统查看操作系统版本信息、CPU信息、模块信息
在Linux系统中,常用命令可帮助用户查看操作系统版本、CPU信息和模块信息
109 23
|
1月前
|
安全 大数据 Linux
云上体验最佳的服务器操作系统 - Alibaba Cloud Linux | 飞天技术沙龙-CentOS 迁移替换专场
本次方案的主题是云上体验最佳的服务器操作系统 - Alibaba Cloud Linux ,从 Alibaba Cloud Linux 的产生背景、产品优势以及云上用户使用它享受的技术红利等方面详细进行了介绍。同时,通过国内某社交平台、某快递企业、某手机客户大数据业务 3 大案例,成功助力客户实现弹性扩容能力提升、性能提升、降本增效。 1. 背景介绍 2. 产品介绍 3. 案例分享
|
2月前
|
Linux Shell 网络安全
Kali Linux系统Metasploit框架利用 HTA 文件进行渗透测试实验
本指南介绍如何利用 HTA 文件和 Metasploit 框架进行渗透测试。通过创建反向 shell、生成 HTA 文件、设置 HTTP 服务器和发送文件,最终实现对目标系统的控制。适用于教育目的,需合法授权。
88 9
Kali Linux系统Metasploit框架利用 HTA 文件进行渗透测试实验
|
3月前
|
缓存 Java Linux
如何解决 Linux 系统中内存使用量耗尽的问题?
如何解决 Linux 系统中内存使用量耗尽的问题?
275 48
|
2月前
|
安全 Linux KVM
Linux虚拟化技术:从Xen到KVM
Xen和KVM是Linux平台上两种主要的虚拟化技术,各有优缺点和适用场景。通过对比两者的架构、性能、安全性、管理复杂性和硬件依赖性,可以更好地理解它们的适用场景和选择依据。无论是高性能计算、企业虚拟化还是云计算平台,合理选择和配置虚拟化技术是实现高效、稳定和安全IT环境的关键。
117 8
|
2月前
|
存储 监控 Linux
嵌入式Linux系统编程 — 5.3 times、clock函数获取进程时间
在嵌入式Linux系统编程中,`times`和 `clock`函数是获取进程时间的两个重要工具。`times`函数提供了更详细的进程和子进程时间信息,而 `clock`函数则提供了更简单的处理器时间获取方法。根据具体需求选择合适的函数,可以更有效地进行性能分析和资源管理。通过本文的介绍,希望能帮助您更好地理解和使用这两个函数,提高嵌入式系统编程的效率和效果。
120 13