初学编程时,你是不是很好奇编译好的可执行文件是如何在系统上跑起来的呢?...今天就让霞姐带你一起研究一下吧~ 一、可执行文件布局 1.ELF格式简介 Linux上可执行文件是ELF(Executable and Linkable Format)格式的。...ELF是 UNIX/Linux 系统的标准二进制文件格式,可用于可执行文件、可链接目标文件(.o),共享库(so)。...GNU_STACK 指定程序栈的权限(RW 表示可读可写,无执行权限),是 Linux 系统的安全机制(防止栈上的代码被执行,对抗缓冲区溢出攻击)。...当我们在linux的shell上输入可执行文件的名字(比如:aaa),并按回车的时候,接下来发生了什么?
在cmd或者powershell执行以下命令set GOARCH=amd64go env -w GOARCH=amd64set GOOS=linuxgo env -w GOOS=linux然后正常go...build即可再切换回windowsgo env -w GOARCH=amd64go env -w GOOS=windows又可以愉快的编译exe可执行文件啦
一、操作目的和应用场景 Capabilities机制是在Linux内核2.2之后引入的,原理很简单,就是将之前与超级用户root(UID=0)关联的特权细分为不同的功能组,Capabilites作为线程...(Linux并不真正区分进程和线程)的属性存在,每个功能组都可以独立启用和禁用。...其本质上就是将内核调用分门别类,具有相似功能的内核调用被分到同一组中。...(二)利用Capabilities实现权限提升 现在假设管理员对一些可执行文件设置了capabilities。测试人员通过下面的命令查找这些文件: getcap -r / 2>/dev/null ?...在kali linux上提权成功,获取了root shell。 在CentOS 7系统中安装的低版本php无法提权: ?
这里我们使用的案例是通过TMalign这个蛋白质打分文件,在编译好可执行文件之后,可以使用建立软链接的方法快捷的使用该可执行文件。...Mac可能需要去掉static): $ g++ -static -O3 -ffast-math -lm -o TMalign TMalign.cpp 编译之后就会在当前路径下生成一个名为TMalign的可执行文件...,有时候会遇到想把可执行文件放在特定的路径下的问题,比如放到/usr/bin目录下,这样可以全局可调用,又不需要手动添加各种乱七八糟的系统路径。...这就需要使用到Linux中的软链接的功能,通常使用ln -s的指令即可。...本文顺带介绍了蛋白质结构评分软件TMalign的源码下载和安装使用的基本方法,编译成一个可执行文件后,可以建立一个软链接,在系统各处都可以使用,是一个比较基础的操作。
Linux可执行文件与进程的虚拟地址空间 一个可执行文件被执行的同时也伴随着一个新的进程的创建。...Linux会为这个进程创建一个新的虚拟地址空间,然后会读取可执行文件的文件头,建立虚拟地址空间与可执行文件的映射关系,然后将CPU的指令指针寄存器设置成可执行文件的入口地址,然后CPU就会从这里取指令执行...一个可执行文件包含可被CPU执行的指令和待处理的数据,上CPU之前,指令和数据全部被翻译成成二进制的形式。在可执行的文件的内部,划分出了一些专门的段,如代码段,数据段,BSS段等。...Proc目录下的进程虚拟地址空间布局 Linux在装载可执行文件的时候,会将这些segment映射到进程的地址空间中。映射的时候,这里面的segment会对应一个VMA。...所以,操作系统实际上并不关心可执行文件各个段所包含的的实际内容,OS只关心一些跟装载相关的问题,最主要的是段的权限(可读,可写,可执行)。
在本指南中,您将在Linux上使用Podman部署MyEMS。前提主机上已安装podman、npm。已安装MySQL服务器。MySQL数据库可以从Podman Engine运行的主机连接。...--restart 重新启动策略以在容器退出时应用--name 为容器指定名称冒号前的绝对路径表示主机上的路径,可能因系统而异。 冒号后的绝对路径用于容器上的路径,不能更改。...--restart 重新启动策略以在容器退出时应用--name 为容器指定名称冒号前的绝对路径表示主机上的路径,可能因系统而异。 冒号后的绝对路径用于容器上的路径,不能更改。...--restart 重新启动策略以在容器退出时应用--name 为容器指定名称冒号前的绝对路径表示主机上的路径,可能因系统而异。 冒号后的绝对路径用于容器上的路径,不能更改。...--restart 重新启动策略以在容器退出时应用--name 为容器指定名称冒号前的绝对路径表示主机上的路径,可能因系统而异。 冒号后的绝对路径用于容器上的路径,不能更改。
引言 上一篇文章中,我们介绍了如何让汇编语言与 C 语言相互调用: 如何实现汇编语言与 C 语言之间的相互调用 还记得我们自制操作系统的脚步到哪里了呢?...在 linux 中,可执行文件、Object文件、动态库文件都是ELF格式文件,他相当于 windows 操作系统中的 PE 文件。 通过 readelf 命令可以读取 ELF 文件的内容。 3....这里提到了“节”的概念,上一篇文章中,我们在汇编中使用了 section 关键字,就是指定了对应代码块的 section 类型,linux 支持下面的三种 section: .text — 代码段,用来存放代码...别忘了我们的目标,我们需要通过汇编语言编写的 loader 程序将在 linux 环境上编译的 C 语言内核程序载入到内存并执行,因此,实际上我们只需要知道 ELF 文件需要如何被载入内存,并从哪里开始执行...了解了上面的结构信息,你就会发现,事实上与我们的目标直接相关的是 ELF 文件中的 Program Header 部分,他描述了可执行文件中有那几个段,每个段需要被载入到内存的哪个位置,而每个段包含多少个节
对于使用场景不是很复杂的,我们可以直接做成一个可执行文件,这样开发者只需要维护可执行文件的功能正常,以及对于各种平台的兼容性较好,这就可以了。...构造python测试实例 因为可执行文件的自身内容都是固定的,只能通过配置文件或者是命令行的输入参数来进行传参,因此我们构造python文件的时候主要从命令行的这个角度来出发,通过读取命令行的输入参数来决定...那么最后还缺一步,就是我们如果想要通过项目名 -参数表示 参数这样的方法来运行我们的项目的话,就需要把这个可执行文件添加到系统路径中。...最常用的方法其实是直接将该可执行文件拷贝到/usr/bin/目录下,这样该可执行文件就可以直接使用,BLACKPINK不需要在前面加上路径就能运行。...总结概要 通过pyinstaller我们可以将一个python项目打包编译构建成一个可执行文件,然后将该可执行文件放置到一个系统路径下,使得系统可以不需要路径也能够识别到这个可执行文件,这样我们就可以仅配置一些输入文件或者命令行的入参
可执行文件的符号表(symbol table)记录了某个可执行文件中的函数名、全局变量、宏定义等符号信息,这些信息对于我们调试十分重要。...目前,我正在DragonOS上开发内核栈traceback程序,因此需要导出内核文件的符号表.这个时候就需要用到Linux的nm命令。...nm命令属于GNU binutils的功能,能够输出可执行文件的符号表。它的用法是这样的: 用法:nm [选项] [文件] 列举 [文件] 中的符号 (默认为 a.out)。...效果如下图: 图片 图片中所看到的就是DragonOS内核的符号表。最左侧一栏指的是符号在内核文件中的地址,中间一栏表示符号类型,最右侧的表示符号的名称。...对于符号的类型的字母的含义,有下列的解释: -A, -o, --print-file-name 在找到的各个符号的名字前加上文件名,而不是在此文件的所有符号前只出现文件名一次 -a, --debug-syms
大家好,又见面了,我是你们的朋友全栈君。...Python生成可执行文件exe 一、安装 pyinstaller pip install pyinstaller 二、使用 pyinstaller 命令 使用示例 相对路径 在程序目录中,运行命令pyinstaller...绝对路径 在程序目录中,运行命令pyinstaller C:\myscript.py 则会在当前执行命令的目录生成dist和build文件夹 常用命令参数 -F 指定打包后只生成一个exe格式的文件...如:pyinstaller -F T1.py 则dist文件只有一个exe格式的文件T1 -i 改变生成程序的icon图标 pyinstaller -F -i ..../my.ico T1.py -n NAME,–name=NAME 设置产生文件的名字(mypy) pyinstaller -F -n mypy -i .
大家好,又见面了,我是你们的朋友全栈君。 在 ADS 下,可执行文件有两种,一种是.axf 文件,带有调试信息,可供 AXD 调试工具使用.另一种是.bin 文件,可执行的二进制代码文件。...我们重点是讲描.bin 文件的组成。 我们把可执行文件分为两种情况:分别为存放态和运行态。 1. 存放态 存放态是指可执行文件通过 fromelf 产生后,在存储介质(flash 或磁盘)上的分布....可执行文件的存放态如下: +————-+———– | .bss | +————-+– 数据段 | .data | +————-+———– | .rodata | | |...运行态 可执行文件通过装载过程, 搬入到 RAM 中运行, 这时候可执行文件就变成运行态。...| 保留区 1 | +————-+– RO 段结束地址 | RO 段 | +————-+– RO 段起始地址 | … | 装载后 所以装载过程必须完成把执行文件的各个段从存储介质上搬到
对于使用场景不是很复杂的,我们可以直接做成一个可执行文件,这样开发者只需要维护可执行文件的功能正常,以及对于各种平台的兼容性较好,这就可以了。...构造python测试实例 因为可执行文件的自身内容都是固定的,只能通过配置文件或者是命令行的输入参数来进行传参,因此我们构造python文件的时候主要从命令行的这个角度来出发,通过读取命令行的输入参数来决定...那么最后还缺一步,就是我们如果想要通过项目名 -参数表示 参数这样的方法来运行我们的项目的话,就需要把这个可执行文件添加到系统路径中。...最常用的方法其实是直接将该可执行文件拷贝到/usr/bin/目录下,这样该可执行文件就可以直接使用,不需要在前面加上路径就能运行。...总结概要 通过pyinstaller我们可以将一个python项目打包编译构建成一个可执行文件,然后将该可执行文件放置到一个系统路径下,使得系统可以不需要路径也能够识别到这个可执行文件,这样我们就可以仅配置一些输入文件或者命令行的入参
一、Linux基本命令 先简单了解一下Linux的命令 这里的mkdir是一个相当于Windows上新建文件夹的操作,创建一个名为super_little_monster的目录,使用ls可以显示出该目录下的所有子目录与文件...的作用是帮助用户定位当前目录下的一个文件,因为在Linux中我们跑我们写出的c代码后会产生可执行程序,此时我们就需要使用 ./a.out 来执行a程序,这里的 ....5、mkdir指令 mkdir [选项] name 用来创建目录,名为name 常用选项有一个 -p 它可以一次创建多个目录 为了方便我们查看一次创建多个目录的效果,我在Linux上安装了tree...,因为我们整个Linux是一个多叉树的结构,这个tree可以帮助我们查看我们的目录 通过分隔符分隔,就会创建出一系列的目录 6、rmdir指令 rmdir用来删除空目录 rmdir [name...这里介绍两个指令,echo和cat,echo用来打印后面的内容,加上>就可以将内容写到文件中,这种行为叫做输出重定向,本来该显示到屏幕上的内容打印到了文件中,cat用来打印文件的内容 10、
linux命令行下面执行某个命令的时候,首先保证该命令是否存在,若存在,但输入命令的时候若仍提示:command not found 这个时候就的查看PATH环境变量的设置了,当前命令是否存在于PATH...环境变量中 #查看PATH: echo $PATH 举例说,命令 composr 在/usr/loca/bin 但执行的时候提示: -bash: composr: command not found 这个时候...#生效方法:立即生效 #有效期限:临时改变,只能在当前的终端窗口中有效,当前窗口关闭后就会恢#复原有的path配置 #用户局限:仅对当前用户 方法二: #通过修改.bashrc文件: vim ~/.bashrc
1969-1970年,AT&T的贝尔实验室研究人员Ken Tompson和Dennis Ritchie,在采用很多Multics特点的基础 上开发了UINX系统。...UNIX不同版本的出现导致了UNIX标准的需要,软件开发商不知道他们的程序运行在哪些版本上比较合适。 到80年代中期,两个竞争的标准出现了,一个是基于AT&T的UNIX版本,另一个是BSD版本。...读者也 许猜想所发布的这个系统应该是Linux的0.01版本,实际上不是这样。真正的Linux 0.01版本并没有被发 布,原因是0.01版本不实用。...Linus仅仅在第一个Linux的FTP站点(ftp://nic.funet.fi)上提供过这个版本 的的源代码。...这种全局变量在这里就有说明 8 是系统管理用的命令,这些命令只能由root使用,如ifconfig 可以看见通过man -ls可以查看很多选项 通过man -k num可以查看手册上的很多指令
要想在Linux系统上实现逆向工程,分析,设计或查杀病毒和恶意代码,你不得不深入掌握其可执行文件的ELF格式,这样你才能了解进程在内存空间的布局和运行的基本规律,这样你才能有针对性的设计有效的病毒或恶意代码入侵系统...ET_EXEC表示可执行文件,它是由多个.o文件链接起来,可以被加载到内存进行执行的进程数据文件;ET_DYN表示动态链接库,它里面包含一系列向外导出的函数代码,当进程需要调用其内部函数时会将其加载到内存...ELF格式的可执行文件在概念上由各种”段“组成,例如用于存储代码的文本段,用于存储数据的数据段等,这些段的数量和相关信息就由程序表头来描述,在加载运行ELF可执行文件时,系统会读取程序表头,获得各个段的信息...,将段对应的内容加载到内存,这样可执行文件才能变成可以运行的进程,我们可以使用命令readelf -l 来读取程序表头的内容,具体情况如下: ?...但所谓黑客,本质上是无限制扩充自己技术能力圈的程序员,因此我们需要掌握哪些工作上不常用,但能帮你探寻到技术核心真相的知识和信息,这就像黑客帝国中莫非是拉尼奥入伙时给出的两颗药丸,吞入红色药丸他就能理解世界的本质
在Linux系统中,可执行文件和库文件的查找路径是由环境变量控制的,其中最重要的是PATH环境变量用于可执行文件,而动态库的查找路径则由LD_LIBRARY_PATH环境变量决定。...下面分别介绍这两个方面: 可执行文件的搜索路径(PATH) PATH环境变量:当你在命令行输入一个命令并敲击回车时,Linux会按照PATH环境变量中列出的目录顺序依次查找该命令的可执行文件。...验证:可以用echo $PATH查看当前的PATH设置,用which command_name查看特定命令的完整路径。...动态库文件的搜索路径(LD_LIBRARY_PATH) LD_LIBRARY_PATH环境变量:当一个程序在运行时需要加载动态链接库(.so文件),Linux会按照LD_LIBRARY_PATH变量中列出的目录顺序查找这些库文件...验证:可以使用ldd command_name命令查看某个可执行文件依赖的动态库及其加载路径。 注意事项: 永久设置环境变量时,务必考虑其影响范围(全局或单用户)以及潜在的安全风险。
我们的主角 :PyInstaller PyInstaller 是一个十分有用的第三方库,可以用来打包 python 应用程序,打包完的程序就可以在没有安装 Python 解释器的机器上运行了。...PyInstaller将 Python应用程序冻结(打包)在Windows,GNU / Linux,Mac OS X,FreeBSD,Solaris和AIX下的独立可执行文件中。...与类似工具相比,PyInstaller的主要优势在于PyInstaller可与Python 2.7和3.5-3.7一起使用;由于透明压缩,它可生成较小的可执行文件;它是完全多平台的;并且使用OS支持来加载动态库...产生单个的可执行文件 -D,--onedir 产生一个目录(包含多个文件)作为可执行程序 -a,--ascii 不包含 Unicode 字符集支持 -d,--debug 产生 debug 版本的可执行文件...也可使用路径分隔符(Windows 使用分号,Linux 使用冒号)来分隔多个路径 -n NAME,--name=NAME 指定项目(产生的 spec)名字。
Linux上安装msf的过程 依次输入下面四个指令即可 curl https://raw.githubusercontent.com/rapid7/metasploit-omnibus/master/
其中最重要的增强之处是,Docker现在可以使用Hyper-V技术在Windows上运行Linux容器。...在Windows上运行Docker Linux容器需要一个最小的Linux内核和用户空间来承载容器进程。...展望未来 Windows Server Insider版本和Windows上的Linux容器的Docker支持处于早期预览模式。...在GA中,Windows上的Docker Linux容器将改善Windows开发人员和服务器管理员的Docker Linux容器体验。...而喜欢Windows的IT管理员很快就能够通过Windows上的Docker Linux容器轻松运行(大部分)Linux系统软件,例如HAProxy和Redis。