當前位置:生活全書館 >

綜合知識

> vivo手機root守護進程怎麼啓動

vivo手機root守護進程怎麼啓動

1、首先開啟手機,在手機桌面上找到設定並點擊進入。

vivo手機root守護進程怎麼啓動

2、進入到設定介面後,選擇介面中的USB設定,接着開啟USB調試,並把手機和電腦連接起來。

3、在電腦的瀏覽器上搜尋一鍵ROOT軟件進行下載,然後把下載下來的root工具包在電腦上進行解壓。

4、在解壓出來的root工具包中找到exe格式的檔案,然後直接雙擊開啟。

5、開啟root工具後就會識別到vivo手機,然後點擊一鍵ROOT就開啓root了,等一段時間後,vivo手機就root成功了,這樣vivo root權限就開啟了。

小編還爲您整理了以下內容,可能對您也有幫助:

  可能很多夥伴對於守護進程都很陌生,甚至都不知道守護進程是什麼。守護進程是操作系統後臺的一種特殊進程,像Linux系統的大多數服務器都是透過守護進程實現的。今天給大家科普一下什麼是守護進程以及linux系統如何創建守護進程。   一、守護進程是什麼?   Linux Daemon(守護進程)是執行在後臺的一種特殊進程。它獨立於控制終端並且週期性地執行某種任務或等待處理某些發生的事件。它不需要用戶輸入就能執行而且提供某種服務,不是對整個系統就是對某個用戶程序提供服務。Linux系統的大多數服務器就是透過守護進程實現的。常見的守護進程包括系統日誌進程syslogd、 web服務器httpd、郵件服務器sendmail和數據庫服務器mysqld等。   守護進程一般在系統啓動時開始執行,除非強行終止,否則直到系統關機都保持執行。守護進程經常以超級用戶(root)權限執行,因爲它們要使用特殊的端口(1-1024)或訪問某些特殊的資源。   一個守護進程的父進程是init進程,因爲它真正的父進程在fork出子進程後就先於子進程exit退出了,所以它是一個由init繼承的孤兒進程。守護進程是非交互式程序,沒有控制終端,所以任何輸出,無論是向標準輸出設備stdout還是標準出錯設備stderr的輸出都需要特殊處理。   守護進程的名稱通常以d結尾,比如sshd、xinetd、crond等   二、創建守護進程的步驟   首先我們要了解一些基本概念:   1、進程組 :  每個進程也屬於一個進程組  每個進程主都有一個進程組號,該號等於該進程組組長的PID號 。  一個進程只能爲它自己或子進程設定進程組ID號   2、會話期:  會話期(session)是一個或多個進程組的集合。  setsid()函數可以建立一個對話期:  如果,調用setsid的進程不是一個進程組的組長,此函數創建一個新的會話期。  (1)此進程變成該對話期的首進程  (2)此進程變成一個新進程組的組長進程。  (3)此進程沒有控制終端,如果在調用setsid前,該進程有控制終端,那麼與該終端的聯繫被解除。 如果該進程是一個進程組的組長,此函數返回錯誤。  (4)爲了保證這一點,我們先調用fork()然後exit(),此時只有子進程在執行  現在我們來給出創建守護進程的所需步驟:  編寫守護進程的一般步驟:  (1)在父進程中執行fork並exit推出;  (2)在子進程中調用setsid函數創建新的會話;  (3)在子進程中調用chdir函數,讓根目錄 ”/” 成爲子進程的工作目錄;  (4)在子進程中調用umask函數,設定進程的umask爲0;  (5)在子進程中關閉任何不需要的檔案描述符  說明:  (1)在後臺執行。  爲避免掛起控制終端將Daemon放入後臺執行。方法是在進程中調用fork使父進程終止,讓Daemon在子進程中後臺執行。  if(pid=fork())  exit(0);//是父進程,結束父進程,子進程繼續  (2)脫離控制終端,登入會話和進程組  有必要先介紹一下Linux中的進程與控制終端,登入會話和進程組之間的關係:進程屬於一個進程組,進程組號(GID)就是進程組長的進程號(PID)。登入會話可以包含多個進程組。這些進程組共享一個控制終端。這個控制終端通常是創建進程的登入終端。  控制終端,登入會話和進程組通常是從父進程繼承下來的。我們的目的就是要擺脫它們,使之不受它們的影響。方法是在第1點的基礎上,調用setsid()使進程成爲會話組長:  setsid();  說明:當進程是會話組長時setsid()調用失敗。但第一點已經保證進程不是會話組長。setsid()調用成功後,進程成爲新的會話組長和新的進程組長,並與原來的登入會話和進程組脫離。由於會話過程對控制終端的獨佔性,進程同時與控制終端脫離。  (3) 禁止進程重新開啟控制終端  現在,進程已經成爲無終端的會話組長。但它可以重新申請開啟一個控制終端。可以透過使進程不再成爲會話組長來禁止進程重新開啟控制終端:  if(pid=fork())  exit(0);//結束第一子進程,第二子進程繼續(第二子進程不再是會話組長)  (4)關閉開啟的檔案描述符  進程從創建它的父進程那裏繼承了開啟的檔案描述符。如不關閉,將會浪費系統資源,造成進程所在的檔案系統無法卸下以及引起無法預料的錯誤。按如下方法關閉它們:  for(i=0;i 關閉開啟的檔案描述符close(i);>  (5) 改變當前工作目錄  進程活動時,其工作目錄所在的檔案系統不能卸下。一般需要將工作目錄改變到根目錄。對於需要轉儲核心,寫執行日誌的進程將工作目錄改變到特定目錄如/tmpchdir("/")  (6)重設檔案創建掩模  進程從創建它的父進程那裏繼承了檔案創建掩模。它可能修改守護進程所創建的檔案的存取位。爲防止這一點,將檔案創建掩模清除:umask(0);  (7)處理SIGCHLD信號  處理SIGCHLD信號並不是必須的。但對於某些進程,特別是服務器進程往往在請求到來時生成子進程處理請求。如果父進程不等待子進程結束,子進程將成爲殭屍進程(zombie)從而佔用系統資源。如果父進程等待子進程結束,將增加父進程的負擔,影響服務器進程的併發性能。在Linux下可以簡單地將SIGCHLD信號的操作設爲SIG_IGN。  signal(SIGCHLD,SIG_IGN);  這樣,內核在子進程結束時不會產生殭屍進程。這一點與BSD4不同,BSD4下必須顯式等待子進程結束才能釋放殭屍進程。   三、創建守護進程   在創建之前我們先了解setsid()使用:#include <unistd.h>       pid_t setsid(void);DESCRIPTION        setsid()  creates a new session if the calling process is not a process        group leader.  The calling process is the leader of  the  new  session,        the  process group leader of the new process group, and has no control-        ling tty.  The process group ID and session ID of the  calling  process        are set to the PID of the calling process.  The calling process will be        the only process in this new process group and in this new session.  //調用進程必須是非當前進程組組長,調用後,產生一個新的會話期,且該會話期中只有一個進程組,且該進程組組長爲調用進程,沒有控制終端,新產生的group ID 和 session ID 被設定成調用進程的PIDRETURN VALUE        On success, the (new) session ID of the calling  process  is  returned.        On  error,  (pid_t) -1  is  returned,  and errno is set to indicate the        error.  現在根據上述步驟創建一個守護進程:  以下程序是創建一個守護進程,然後利用這個守護進程每個一分鐘向daemon.log檔案中寫入當前時間01#include <stdio.h>02#include <unistd.h>03#include <stdlib.h>04#include <time.h>05#include <fcntl.h>06#include <string.h>07#include <sys/stat.h>08#define ERR_EXIT(m) 9do10{11perror(m);12exit(EXIT_FAILURE);13}14while (0);15void creat_daemon(void);16int main(void)17{18time_t t;19int fd;20creat_daemon();21while(1){22fd = open("daemon.log",O_WRONLY|O_CREAT|O_APPEND,0644);23if(fd == -1)24ERR_EXIT("open error");25t = time(0);26char *buf = asctime(localtime(&t));27write(fd,buf,strlen(buf));28close(fd);29sleep(60);30}31return 0;32}33void creat_daemon(void)34{35pid_t pid;36pid = fork();37if( pid == -1)38ERR_EXIT("fork error");39if(pid > 0 )40exit(EXIT_SUCCESS);41if(setsid() == -1)42ERR_EXIT("SETSID ERROR");43chdir("/");44int i;45for( i = 0; i < 3; ++i)46{47close(i);48open("/dev/null", O_RDWR);49dup(0);50dup(0);51}52umask(0);53return;54}複製代碼  結果:
 守護進程是什麼?linux創建守護進程的步驟詳解  結果顯示:當我一普通用戶執行a.out時,進程表中並沒有出現新創建的守護進程,但當我以root用戶執行時,成功了,並在/目錄下創建了daemon.log檔案,cat檢視後確實每個一分鐘寫入一次。爲什麼只能root執行,那是因爲當我們創建守護進程時,已經將當前目錄切換我/目錄,所以當我之後創建daemon.log檔案是其實是在/目錄下,那肯定不行,因爲普通用戶沒有權限,或許你會問那爲啥沒報錯呢?其實是有出錯,只不過我們在創建守護進程時已經將標準輸入關閉並重定向到/dev/null,所以看不到錯誤資訊。   四、利用庫函數daemon()創建守護進程   其實我們完全可以利用daemon()函數創建守護進程,其函數原型:#include <unistd.h>int daemon(int nochdir, int noclose);DESCRIPTION        The daemon() function is for programs wishing to detach themselves from        the controlling terminal and run in the background as system daemons.       If nochdir is zero, daemon()  changes  the  process’s  current  working        directory to the root directory ("/"); otherwise,       If  noclose is zero, daemon() redirects standard input, standard output        and standard error to /dev/null; otherwise,  no  changes  are  made  to        these file descriptors.  功能:創建一個守護進程  參數:  nochdir:=0將當前目錄更改至“/”  noclose:=0將標準輸入、標準輸出、標準錯誤重定向至“/dev/null”  返回值:  成功:0  失敗:-1  現在我們利用daemon()改寫剛纔那個程序:01#include <stdio.h>02#include <unistd.h>03#include <stdlib.h>04#include <time.h>05#include <fcntl.h>06#include <string.h>07#include <sys/stat.h>08#define ERR_EXIT(m) 9do10{11perror(m);12exit(EXIT_FAILURE);13}14while (0);15void creat_daemon(void);16int main(void)17{18time_t t;19int fd;20if(daemon(0,0) == -1)21ERR_EXIT("daemon error");22while(1){23fd = open("daemon.log",O_WRONLY|O_CREAT|O_APPEND,0644);24if(fd == -1)25ERR_EXIT("open error");26t = time(0);27char *buf = asctime(localtime(&t));28write(fd,buf,strlen(buf));29close(fd);30sleep(60);31}32return 0;33}複製代碼  當daemon(0,0)時: 守護進程是什麼?linux創建守護進程的步驟詳解  結果同剛纔一樣,也是隻有root才能成功,普通用戶執行時看不到錯誤資訊  現在讓daemon(0,1),就是不關閉標準輸入輸出結果: 守護進程是什麼?linux創建守護進程的步驟詳解  可以看到錯誤資訊  現在讓daemon(1,0),就是不重定向,結果如下: 守護進程是什麼?linux創建守護進程的步驟詳解  這次普通用戶執行成功了,以爲沒有切換到/目錄下,有權限  其實我們可以利用我們剛纔寫的創建守護進程程序默認daemon()實現:  代碼如下:01#include <stdio.h>02#include <unistd.h>03#include <stdlib.h>04#include <time.h>05#include <fcntl.h>06#include <string.h>07#include <sys/stat.h>08#define ERR_EXIT(m) 9do10{11perror(m);12exit(EXIT_FAILURE);13}14while (0);15void creat_daemon(int nochdir, int noclose);16int main(void)17{18time_t t;19int fd;20creat_daemon(0,0);21while(1){22fd = open("daemon.log",O_WRONLY|O_CREAT|O_APPEND,0644);23if(fd == -1)24ERR_EXIT("open error");25t = time(0);26char *buf = asctime(localtime(&t));27write(fd,buf,strlen(buf));28close(fd);29sleep(60);30}31return 0;32}33void creat_daemon(int nochdir, int noclose)34{35pid_t pid;36pid = fork();37if( pid == -1)38ERR_EXIT("fork error");39if(pid > 0 )40exit(EXIT_SUCCESS);41if(setsid() == -1)42ERR_EXIT("SETSID ERROR");43if(nochdir == 0)44chdir("/");45if(noclose == 0){46int i;47for( i = 0; i < 3; ++i)48{49close(i);50open("/dev/null", O_RDWR);51dup(0);52dup(0);53}54umask(0);55return;56}複製代碼  關於linux系統創建守護進程的操作步驟就給大家講解到這裏了,在這方面有需要的,不妨按上述操作一下。要啓動vivo手機的root守護進程,您可以按照以下步驟進行操作:

1. 首先,確保您的vivo手機已經成功獲取了root權限。如果您還沒有root權限,您可以在互聯網上查找相關的教程,並按照教程進行root操作。

2. 一旦您的vivo手機已經成功獲取了root權限,您可以下載一個名爲SuperSU的應用程序。SuperSU是一個常用的root管理工具,可以幫助您管理和監控root權限。

3. 安裝完SuperSU後,開啟應用程序。您可能會被提示更新SU二進制檔案,如果出現這樣的提示,請點擊繼續或更新來完成更新。

4. 更新完成後,您將看到一個SU二進制已更新的提示。接下來,您可以在SuperSU中找到一個名爲SU守護進程或守護進程的選項。

5. 點擊SU守護進程選項,並確保它處於啓用狀態。這將啓動vivo手機的root守護進程,以確保您的root權限正常執行並保持安全。

請注意,這些步驟可能會因不同的vivo手機型號而有所差異。如果您遇到任何困難或問題,建議您參考vivo手機的官方文檔或與vivo的客戶支援團隊聯繫,以獲取更準確的指導和幫助。

標籤: root 進程 守護 vivo
  • 文章版權屬於文章作者所有,轉載請註明 https://shqsg.com/zh-hant/zonghezhishi/kkp0ly.html