Linux是一种开源操作系统,它被广泛用于服务器,工作站和个人计算机。Linux的控制台输出是在终端窗口中打印的文本信息,它提供了有关系统状态,程序执行和错误信息的有用信息。
10年的凉州网站建设经验,针对设计、前端、开发、售后、文案、推广等六对一服务,响应快,48小时及时工作处理。网络营销推广的优势是能够根据用户设备显示端的尺寸不同,自动调整凉州建站的显示方式,使网站能够适用不同显示终端,在浏览器中调整网站的宽度,无论在任何一种浏览器上浏览网站,都能展现优雅布局与设计,从而大程度地提升浏览体验。创新互联公司从事“凉州网站设计”,“凉州网站推广”以来,每个客户项目都认真落实执行。
本文将讨论如何在Linux中获取控制台输出。
1. 查看系统日志
Linux的系统日志是一个重要的工具,可以帮助您诊断和解决系统问题。您可以通过以下命令查看系统日志:
“`
sudo cat /var/log/syslog
“`
这将打印出系统的所有日志消息。您可以使用grep命令过滤或搜索特定的日志消息:
“`
sudo cat /var/log/syslog | grep
“`
2. 监视日志
如果您需要监视系统日志的特定部分,可以使用tl命令。该命令将输出文件的最后几行,因此它对于实时监视日志非常有用。以下是使用tl命令监视系统日志的示例:
“`
sudo tl -f /var/log/syslog
“`
3. 查找文件日志
除了系统日志外,应用程序也会生成日志文件。如果您需要查看应用程序的日志,可以查找它们并打印它们的内容。以下是查找和打印文件日志的示例:
“`
sudo find /var/log -name “” -print0 | xargs -0 cat
“`
将“替换为要查找和打印的日志文件的名称。
4. 查看正在运行的进程
在Linux中查看正在运行的进程是一个常见的任务。您可以使用以下命令列出所有正在运行的进程:
“`
ps -ef
“`
这将打印所有正在运行的进程的详细信息,包括PID(进程ID),PPID(父进程ID)和CPU利用率等。
5. 查看进程的输出
在Linux中,某些进程可在控制台上输出诊断信息和错误消息。您可以使用以下命令捕获正在运行的进程的输出:
“`
sudo strace -p
“`
将“替换为要捕获输出的进程的PID。
6. 捕获Shell输出
如果您在Linux中使用的是Bash或其他Shell,可以使用以下命令捕获Shell的所有输出:
“`
script -a
“`
将“替换为要保存输出的文件名称。执行此命令后,Shell的所有输出都将被写入指定的文件中。
7. 检查内核日志
内核日志包含有关系统硬件和驱动程序的重要信息。您可以使用以下命令查看内核日志:
“`
sudo dmesg
“`
这将打印内核日志的所有消息。您可以使用grep命令过滤或搜索特定的日志消息:
“`
sudo dmesg | grep
“`
相关问题拓展阅读:
内核中的bug也是多种多样的。它们的产生有无数的原因,同时表象也变化多端。从隐藏在源代码中的错误到展现在目击者面前的bug,其发作往往是一系列连锁反应的事件才可能出发的。虽然内核调试有一定的困难,但是通过你的努力和理解,说不定你会喜欢上这样的挑战。
最近工作在调试u虚拟串口,让其作为kernel启动的调试串口,以及user空间的输入输出控制台。
利用这个机会,学习下printk如何选择往哪个console输出以及user空间下控制台如何选择,记录与此,与大家共享,也方便自己以后翻阅。
Kernel版本号:3.4.55
依照我的思路(还是时间顺序)分了4部分,指定kernel调试console , kernel下printk console的选择 ,kernel下console的注册,user空间console的选择。
一 指定kernel调试console
首先看kernel启动时如何获取和处理指定的console参数。
kernel的启动参数cmdline可以指定调试console,如指定‘console=ttyS0,115200’,
kernel如何解析cmdline,我之前写了一篇博文如下:
根据之前的分析,cmdline中有console=xxx,start_kernel中parse_args遍历.init.setup段所有obs_kernel_param。
kernel/printk.c中注册了‘console=’的解析函数console_setup(注册了obs_kernel_param),所以匹配成功,会调用console_setup来解析,如下:
view plain copy
static int __init console_setup(char *str)
{
char buf.name) + 4>; /* 4 for index */
char *s, *options, *brl_options = NULL;
int idx;
#ifdef CONFIG_A11Y_BRAILLE_CONSOLE
if (!memcmp(str, “brl,”, 4)) {
brl_options = “”;
str += 4;
} else if (!memcmp(str, “brl=”, 4)) {
brl_options = str + 4;
str = strchr(brl_options, ‘,’);
if (!str) {
printk(KERN_ERR “need port name after brl=\n”);
return 1;
}
*(str++) = 0;
}
#endif
/*
* Decode str into name, index, options.
*/
if (str >= ‘0’ && str = ‘0’ && *s name, name, sizeof(c->name));
c->options = options;
#ifdef CONFIG_A11Y_BRAILLE_CONSOLE
c->brl_options = brl_options;
#endif
c->index = idx;
return 0;
}
kernel利用结构体数组console_cmdline,最多可支持8个cmdline传入的console参数。
__add_preferred_console将name idx options保存到数组下一个成员console_cmdline结构体中,如果数组中已有重名,则不添加,并置selected_console为最新添加的console_cmdline的下标号。
比如cmdline中有“console=ttyS0,console=ttyS1,9600”
则在console_cmdline数组中console_cmdline代表ttyS0,console_cmdline代表ttyS1,而selected_console=1.
二 kernel下printk console的选择
kernel下调试信息是通过printk输出,如果要kernel正常打印,则需要搞明白printk怎么选择输出的设备。
关于printk的实现原理,我在刚工作的时候写过一篇博文,kernel版本是2.6.21的,但是原理还是一致的,可供参考:
printk首先将输出内容添加到一个kernel缓冲区中,叫log_buf,log_buf相关代码如下:
view plain copy
#define MAX_CMDLINECONSOLES 8
static struct console_cmdline console_cmdline;
static int selected_console = -1;
static int preferred_console = -1;
int console_set_on_cmdline;
EXPORT_SYMBOL(console_set_on_cmdline);
/* Flag: console code may call schedule() */
static int console_may_schedule;
#ifdef CONFIG_PRINTK
static char __log_buf;
static char *log_buf = __log_buf;
static int log_buf_len = __LOG_BUF_LEN;
static unsigned logged_chars; /* Number of chars produced since last read+clear operation */
static int saved_console_loglevel = -1;
log_buf的大小由kernel menuconfig配置,我配置的CONFIG_LOG_BUF_SHIFT为17,则log_buf为128k。
printk内容会一直存在log_buf中,log_buf满了之后则会从头在开始存,覆盖掉原来的数据。
根据printk的实现原理,printk最后调用console_unlock实现log_buf数据刷出到指定设备。
这里先不关心printk如何处理log buf数据(比如添加内容级别),只关心printk如何一步步找到指定的输出设备,根据printk.c代码,可以找到如下线索。
printk->vprintk->console_unlock->call_console_drivers->_call_console_drivers->_call_console_drivers->__call_console_drivers
看线索更底层__call_console_drivers代码。如下:
view plain copy
/*
* Call the console drivers on a range of log_buf
*/
static void __call_console_drivers(unsigned start, unsigned end)
{
struct console *con;
for_each_console(con) {
if (exclusive_console && con != exclusive_console)
continue;
if ((con->flags & CON_ENABLED) && con->write &&
(cpu_online(p_processor_id()) ||
(con->flags & CON_ANYTIME)))
con->write(con, &LOG_BUF(start), end – start);
}
}
for_each_console定义如下:
view plain copy
/*
* for_each_console() allows you to iterate on each console
*/
#define for_each_console(con) \
for (con = console_drivers; con != NULL; con = con->next)
遍历console_drivers链表所有console struct,如果有exclusive_console,则调用与exclusive_console一致console的write,
如果exclusive_console为NULL,则调用所有ENABLE的console的write方法将log buf中start到end的内容发出。
可以看出,execlusive_console来指定printk输出唯一console,如果未指定,则向所有enable的console写。
默认情况下execlusive_console=NULL,所以printk默认是向所有enable的console写!
只有一种情况是指定execlusive_console,就是在console注册时,下面会讲到。
到这里就很明了了,kernel下每次printk打印,首先存log_buf,然后遍历console_drivers,找到合适console(execlusive_console或所有enable的),刷出log。
关于linux获取控制台输出的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。
香港服务器选创新互联,2H2G首月10元开通。
创新互联(www.cdcxhl.com)互联网服务提供商,拥有超过10年的服务器租用、服务器托管、云服务器、虚拟主机、网站系统开发经验。专业提供云主机、虚拟主机、域名注册、VPS主机、云服务器、香港云服务器、免备案服务器等。
当前标题:如何使用Linux获取控制台输出(linux获取控制台输出)
转载来源:http://www.shufengxianlan.com/qtweb/news27/287877.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联