首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

JobObject实现对进程进行内存和运行时间限制

最近在研究oj系统,查过网上的解决方案,大致分为两种: 一种是基于Java虚拟机的解决方案,让编译好的程序运行在java虚拟机里面,通过对虚拟机的限制保障时空有效性和系统安全性; 第二种是基于linux...系统的方案,通过内置的系统函数设置程序可用资源以及通过限制用户运行此程序以保障系统安全性....根据上面的第二种解决方案后查阅MSDN及相关资料后得知windows下没有设置程序可用资源的函数,只有通过JobObject创建一个工作对象以限制运行.关于系统安全性方面则可以采用其他低权限账户运行(...通过AssignProcessToJobObject将工作对象应用到指定进程中. 通过ResumeThread恢复已暂停的进程....通过WaitForSingleObject等待正在运行的工作对象,设置好允许使用时间.

1.9K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Linux下查看进程的启动和运行时间

    有时需要知道某进程运行时间,比如我想知道我sra文件转换成fq格式的转化速度。以便我做好时间安排。...:进程名 lstart:开始时间 etime:运行时间 运行结果如下: 91413 pts/0 root fastq-dump Tue May 21 10:01:44...I 5月09 0:00 [rcu_bh] USER:用户名 %CPU:进程占用的CPU百分比 %MEM:占用内存的百分比 VSZ:该进程使用的虚拟內存量(KB) RSS:该进程占用的固定內存量...(KB)(驻留中页的数量) STAT:进程的状态 START:该进程被触发启动时间 TIME:该进程实际使用CPU运行时间 top命令 top也可以看进程信息,与ps区别如下 ps看命令执行那刻的进程信息...,top是持续监视,ctrl c退出 ps只是查看进程,而top还可以监视系统性能,如平均负载,cpu和内存的消耗 总体来说, ps主要是查看进程的,尤其你关心的进程 top主要看cpu,内存使用情况

    15.3K10

    linux中怎么知道进程运行了多长时间

    你有没有遇到过想知道一个进程在你的 Linux 机器上运行了多长时间的情况? 你不需要任何监控应用程序。...在 Linux 和其他类 Unix 操作系统中,有一个名为 的命令ps,用于显示有关活动进程的信息。使用ps命令,我们可以很容易地找出一个进程在 Linux 中运行了多长时间。...查看一个进程在 Linux 中运行了多长时间 该ps命令具有不同的格式说明符(关键字),可用于控制输出格式。我们将使用以下两个关键字来查找活动进程的正常运行时间。...$ ps -p 8299 -o etimes ELAPSED 14749 不仅是单个进程,我们还可以显示所有进程的正常运行时间,如下所示。...正如你在上面的输出中看到的,我们有六列格式的所有进程的正常运行时间。 PID - 进程 ID。 COMMAND (第二列)- 不带选项和/或参数的命令名称。 STARTED - 进程的绝对开始时间

    8.1K20

    进程和子进程谁先运行

    Linux中,父进程和子进程是并行运行的,先运行哪个是不确定的,在小红帽系统(Red Hat)中,先运行的是子进程,在ubuntu系统中,父进程是先运行的。...其实谁先运行不重要了,一般在编程中,把父进程当做守护进程使用,用一个waitpid(pid,&status,0) != pid 等待子进程的结束,父进程一直阻塞在这个函数中。...把父进程当做守护进程使用 #include #include #include #include int main...Child process ID: %d\n", pid); pid_wait = waitpid(pid, &status, 0); // 等待指定进程号的子进程 printf("Child...\n", pid_wait); } return 0; } 结果(Ubuntu中):父进程等待了子进程结束 ? 如果喜欢我的文章,欢迎关注、点赞和转发,下面可以留言~~~

    3.8K30

    【Linux 内核】CFS 调度器 ③ ( 计算进程 “ 虚拟运行时间 “ )

    文章目录 一、计算进程 " 虚拟运行时间 " 一、计算进程 " 虚拟运行时间 " ---- 在上一篇博客 【Linux 内核】CFS 调度器 ② ( CFS 调度器 “ 权重 “ 概念 | CFS 调度器调度实例...| 计算进程 “ 实际运行时间 “ ) 中 , 计算了 进程 在 CPU 上的 " 实际运行时间 " , CPU 的总时间是 CPU 的调度区 大小 , 则 进程 在 CPU 上执行的进程 可获取到的...CPU 时间 计算公式如下 : \rm 进程获取的CPU 时间 = 调度区 \times \cfrac{进程权重}{所有进程的权重之和} 进程获取的 CPU 时间 , 就是 进程的 实际运行时间 ;...进程权重} \ \ \ \ ① " 实际运行时间 " 公式如下 : \rm 实际运行时间 = 调度周期 \times \cfrac{进程权重}{所有进程的权重之和} \ \ \ \ ② 将 ② 公式带入...调度器 对 进程 进行调度运行时 , 找到 " 虚拟运行时间 " 最小的进程 运行即可 , Linux 内核中 , 进程队列 的数据结构是 " 红黑树 " , 该数据结构 可以最快地找到 " 虚拟运行时间

    2K20

    Linux内核12-进程资源限制

    进程资源限制 每个进程都需要进行资源限制,避免把系统搞垮(比如对CPU的使用,硬盘空间的占用等等)。...RLIM_NLIMITS的大小为16,也就是说,目前对进程资源的限制有16种,分别如下所示: RLIMIT_AS 进程空间的最大值,单位是字节。...RLIMIT_CPU 进程占用CPU的最大时间,单位是秒(S)。如果超过这个时间,内核会发送一个SIGXCPU信号,如果进程还是没有终止,再发送SIGKILL信号。...结构体成员rlim_cur表示对当前进程的资源限制。比如current->signal->rlim[RLIMIT_CPU].rlim_cur是指当前正在运行进程的CPU时间限制。...用户新创建的进程继承它父进程的rlim数组内容,所以,用用也不能覆盖掉由超级用户赋值的限制值。

    2K10

    Linux进程资源限制及优化方法

    在Linux中,每个进程分配的资源是有限制的,以防止某个进程耗尽系统资源,从而影响其他进程的正常运行。开发人员需要时刻关注这些资源的使用情况,避免资源异常导致系统问题。...在Linux中,进程资源限制主要有以下几项(括号内为查看或设置限制值的命令)。 1、进程打开的文件数量限制(ulimit -n) 限制进程能够同时打开的文件数量。...示例:一个服务器程序需要同时处理多个客户端连接,每个连接都会占用一个文件描述符。如果文件描述符的数量限制过低,程序可能会因无法打开新连接而出现错误。...设置示例: * soft as 512000 * hard as 1024000 3、进程CPU时间限制(ulimit -t) 限制进程可以使用的CPU时间(以秒为单位)。...示例:一个计算密集型任务如果运行时间过长,可能会占用大量的CPU资源。通过设置CPU时间限制,可以防止这样的任务过度使用CPU。

    58800

    每台机器的进程平均运行时间

    process_id 是运行在各机器上的进程ID号. activity_type 是枚举类型 (‘start’, ‘end’). timestamp 是浮点类型,代表当前时间(以秒为单位)....‘start’ 代表该进程在这台机器上的开始运行时间戳 , ‘end’ 代表该进程在这台机器上的终止运行时间戳....同一台机器,同一个进程都有一对开始时间戳和结束时间戳,而且开始时间戳永远在结束时间戳前面. 现在有一个工厂网站由几台机器运行,每台机器上运行着相同数量的进程....请写出一条SQL计算每台机器各自完成一个进程任务的平均耗时. 完成一个进程任务的时间进程的’end’ 时间戳 减去 ‘start’ 时间戳....平均耗时通过计算每台机器上所有进程任务的总耗费时间除以机器上的总进程数量获得.

    37710

    进程模式运行Jexus

    本文内容来自《Jexus web server运行于多进程模式时需要注意的事项》,默认情况下,Jexus web server是以单进程模式运行的,当修改jws.config配置文件,把工作进程数量设置为大于...多进程模式运行Jexus就相当于IIS 6的Web Garden。...配置使用多个工作进程可以提高该应用程序池处理请求的性能,但是在设置为使用多个工作进程之前,请考虑以下两点: 每一个工作进程都会消耗系统资源和CPU占用率;太多的工作进程会导致系统资源和CPU利用率的急剧消耗...; 每一个工作进程都具有自己的状态数据,如果Web应用程序依赖于工作进程保存状态数据,那么可能不支持使用多个工作进程。...Session state服务器对session信息进行保存。

    76260

    【Linux】进程状态&&僵尸进程和孤儿进程&&阻塞、挂起和运行

    (running):并不意味着进程一定在运行中,它表明进程要么是在运行中要么在运行队列里。...相比较CPU来讲,大部分时间这个进程都在等待设备资源是否就绪,如果资源不就绪,当前进程就一直出于S状态。...一个进程一旦持有CPU,会一直只运行这个进程吗? 不会,进程基于时间片进行轮转调度的。(而Linux中并不是以这种方法调度的,在之后的博客中会提到,请多多关注。)...让多个进程以切换的方式进程调度,在一个时间段内同时得以推进代码,就叫做并发。 把任何时刻,都有多个进程在真的同时运行,叫做并行。...如果这个进程时间片到了,那么就会把这个进程从CPU上剥离下来,把下一个进程放上去。如果想要把这个进程恢复,就得保存上下文,然后CPU运行到这个进程又继续执行。

    42510
    领券