mirror of
https://github.com/LCTT/TranslateProject.git
synced 2025-01-04 22:00:34 +08:00
20150806-5 选题
This commit is contained in:
parent
f6f0cfde12
commit
60edce17ba
@ -0,0 +1,69 @@
|
|||||||
|
Linux FAQs with Answers--How to enable logging in Open vSwitch for debugging and troubleshooting
|
||||||
|
================================================================================
|
||||||
|
> **Question:** I am trying to troubleshoot my Open vSwitch deployment. For that I would like to inspect its debug messages generated by its built-in logging mechanism. How can I enable logging in Open vSwitch, and change its logging level (e.g., to INFO/DEBUG level) to check more detailed debug information?
|
||||||
|
|
||||||
|
Open vSwitch (OVS) is the most popular open-source implementation of virtual switch on the Linux platform. As the today's data centers increasingly rely on the software-defined network (SDN) architecture, OVS is fastly adopted as the de-facto standard network element in data center's SDN deployments.
|
||||||
|
|
||||||
|
Open vSwitch has a built-in logging mechanism called VLOG. The VLOG facility allows one to enable and customize logging within various components of the switch. The logging information generated by VLOG can be sent to a combination of console, syslog and a separate log file for inspection. You can configure OVS logging dynamically at run-time with a command-line tool called `ovs-appctl`.
|
||||||
|
|
||||||
|
![](https://farm1.staticflickr.com/499/19300367114_cd8aac2fb2_c.jpg)
|
||||||
|
|
||||||
|
Here is how to enable logging and customize logging levels in Open vSwitch with `ovs-appctl`.
|
||||||
|
|
||||||
|
The syntax of `ovs-appctl` to customize VLOG is as follows.
|
||||||
|
|
||||||
|
$ sudo ovs-appctl vlog/set module[:facility[:level]]
|
||||||
|
|
||||||
|
- **Module**: name of any valid component in OVS (e.g., netdev, ofproto, dpif, vswitchd, and many others)
|
||||||
|
- **Facility**: destination of logging information (must be: console, syslog or file)
|
||||||
|
- **Level**: verbosity of logging (must be: emer, err, warn, info, or dbg)
|
||||||
|
|
||||||
|
In OVS source code, module name is defined in each source file in the form of:
|
||||||
|
|
||||||
|
VLOG_DEFINE_THIS_MODULE(<module-name>);
|
||||||
|
|
||||||
|
For example, in lib/netdev.c, you will see:
|
||||||
|
|
||||||
|
VLOG_DEFINE_THIS_MODULE(netdev);
|
||||||
|
|
||||||
|
which indicates that lib/netdev.c is part of netdev module. Any logging messages generated in lib/netdev.c will belong to netdev module.
|
||||||
|
|
||||||
|
In OVS source code, there are multiple severity levels used to define several different kinds of logging messages: VLOG_INFO() for informational, VLOG_WARN() for warning, VLOG_ERR() for error, VLOG_DBG() for debugging, VLOG_EMERG for emergency. Logging level and facility determine which logging messages are sent where.
|
||||||
|
|
||||||
|
To see a full list of available modules, facilities, and their respective logging levels, run the following commands. This command must be invoked after you have started OVS.
|
||||||
|
|
||||||
|
$ sudo ovs-appctl vlog/list
|
||||||
|
|
||||||
|
![](https://farm1.staticflickr.com/465/19734939478_7eb5d44635_c.jpg)
|
||||||
|
|
||||||
|
The output shows the debug levels of each module for three different facilities (console, syslog, file). By default, all modules have their logging level set to INFO.
|
||||||
|
|
||||||
|
Given any one OVS module, you can selectively change the debug level of any particular facility. For example, if you want to see more detailed debug messages of dpif module at the console screen, run the following command.
|
||||||
|
|
||||||
|
$ sudo ovs-appctl vlog/set dpif:console:dbg
|
||||||
|
|
||||||
|
You will see that dpif module's console facility has changed its logging level to DBG. The logging level of two other facilities, syslog and file, remains unchanged.
|
||||||
|
|
||||||
|
![](https://farm1.staticflickr.com/333/19896760146_5d851311ae_c.jpg)
|
||||||
|
|
||||||
|
If you want to change the logging level for all modules, you can specify "ANY" as the module name. For example, the following command will change the console logging level of every module to DBG.
|
||||||
|
|
||||||
|
$ sudo ovs-appctl vlog/set ANY:console:dbg
|
||||||
|
|
||||||
|
![](https://farm1.staticflickr.com/351/19734939828_8c7f59e404_c.jpg)
|
||||||
|
|
||||||
|
Also, if you want to change the logging level of all three facilities at once, you can specify "ANY" as the facility name. For example, the following command will change the logging level of all facilities for every module to DBG.
|
||||||
|
|
||||||
|
$ sudo ovs-appctl vlog/set ANY:ANY:dbg
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://ask.xmodulo.com/enable-logging-open-vswitch.html
|
||||||
|
|
||||||
|
作者:[Dan Nanni][a]
|
||||||
|
译者:[译者ID](https://github.com/译者ID)
|
||||||
|
校对:[校对者ID](https://github.com/校对者ID)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](https://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:http://ask.xmodulo.com/author/nanni
|
@ -0,0 +1,49 @@
|
|||||||
|
Linux FAQs with Answers--How to fix “ImportError: No module named wxversion” on Linux
|
||||||
|
================================================================================
|
||||||
|
> **Question:** I was trying to run a Python application on [insert your Linux distro], but I got an error "ImportError: No module named wxversion." How can I solve this error in the Python program?
|
||||||
|
|
||||||
|
Looking for python... 2.7.9 - Traceback (most recent call last):
|
||||||
|
File "/home/dev/playonlinux/python/check_python.py", line 1, in
|
||||||
|
import os, wxversion
|
||||||
|
ImportError: No module named wxversion
|
||||||
|
failed tests
|
||||||
|
|
||||||
|
This error indicates that your Python application is GUI-based, relying on a missing Python module called wxPython. [wxPython][1] is a Python extension module for the wxWidgets GUI library, popularly used by C++ programmers to design GUI applications. The wxPython extension allows Python developers to easily design and integrate GUI within any Python application.
|
||||||
|
|
||||||
|
To solve this import error, you need to install wxPython on your Linux, as described below.
|
||||||
|
|
||||||
|
### Install wxPython on Debian, Ubuntu or Linux Mint ###
|
||||||
|
|
||||||
|
$ sudo apt-get install python-wxgtk2.8
|
||||||
|
|
||||||
|
### Install wxPython on Fedora ###
|
||||||
|
|
||||||
|
$ sudo yum install wxPython
|
||||||
|
|
||||||
|
### Install wxPython on CentOS/RHEL ###
|
||||||
|
|
||||||
|
wxPython is available on the EPEL repository of CentOS/RHEL, not on base repositories. Thus, first [enable EPEL repository][2] on your system, and then use yum command.
|
||||||
|
|
||||||
|
$ sudo yum install wxPython
|
||||||
|
|
||||||
|
### Install wxPython on Arch Linux ###
|
||||||
|
|
||||||
|
$ sudo pacman -S wxpython
|
||||||
|
|
||||||
|
### Install wxPython on Gentoo ###
|
||||||
|
|
||||||
|
$ emerge wxPython
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://ask.xmodulo.com/importerror-no-module-named-wxversion.html
|
||||||
|
|
||||||
|
作者:[Dan Nanni][a]
|
||||||
|
译者:[译者ID](https://github.com/译者ID)
|
||||||
|
校对:[校对者ID](https://github.com/校对者ID)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](https://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:http://ask.xmodulo.com/author/nanni
|
||||||
|
[1]:http://wxpython.org/
|
||||||
|
[2]:http://xmodulo.com/how-to-set-up-epel-repository-on-centos.html
|
@ -0,0 +1,72 @@
|
|||||||
|
Linux FAQs with Answers--How to install git on Linux
|
||||||
|
================================================================================
|
||||||
|
> **Question:** I am trying to clone a project from a public Git repository, but I am getting "git: command not found" error. How can I install git on [insert your Linux distro]?
|
||||||
|
|
||||||
|
Git is a popular open-source version control system (VCS) originally developed for Linux environment. Contrary to other VCS tools like CVS or SVN, Git's revision control is considered "distributed" in a sense that your local Git working directory can function as a fully-working repository with complete history and version-tracking capabilities. In this model, each collaborator commits to his or her local repository (as opposed to always committing to a central repository), and optionally push to a centralized repository if need be. This brings in scalability and redundancy to the revision control system, which is a must in any kind of large-scale collaboration.
|
||||||
|
|
||||||
|
![](https://farm1.staticflickr.com/341/19433194168_c79d4570aa_b.jpg)
|
||||||
|
|
||||||
|
### Install Git with a Package Manager ###
|
||||||
|
|
||||||
|
Git is shipped with all major Linux distributions. Thus the easiest way to install Git is by using your Linux distro's package manager.
|
||||||
|
|
||||||
|
**Debian, Ubuntu, or Linux Mint**
|
||||||
|
|
||||||
|
$ sudo apt-get install git
|
||||||
|
|
||||||
|
**Fedora, CentOS or RHEL**
|
||||||
|
|
||||||
|
$ sudo yum install git
|
||||||
|
|
||||||
|
**Arch Linux**
|
||||||
|
|
||||||
|
$ sudo pacman -S git
|
||||||
|
|
||||||
|
**OpenSUSE**
|
||||||
|
|
||||||
|
$ sudo zypper install git
|
||||||
|
|
||||||
|
**Gentoo**
|
||||||
|
|
||||||
|
$ emerge --ask --verbose dev-vcs/git
|
||||||
|
|
||||||
|
### Install Git from the Source ###
|
||||||
|
|
||||||
|
If for whatever reason you want to built Git from the source, you can follow the instructions below.
|
||||||
|
|
||||||
|
**Install Dependencies**
|
||||||
|
|
||||||
|
Before building Git, first install dependencies.
|
||||||
|
|
||||||
|
**Debian, Ubuntu or Linux**
|
||||||
|
|
||||||
|
$ sudo apt-get install libcurl4-gnutls-dev libexpat1-dev gettext libz-dev libssl-dev asciidoc xmlto docbook2x
|
||||||
|
|
||||||
|
**Fedora, CentOS or RHEL**
|
||||||
|
|
||||||
|
$ sudo yum install curl-devel expat-devel gettext-devel openssl-devel zlib-devel asciidoc xmlto docbook2x
|
||||||
|
|
||||||
|
#### Compile Git from the Source ####
|
||||||
|
|
||||||
|
Download the latest release of Git from [https://github.com/git/git/releases][1]. Then build and install Git under /usr as follows.
|
||||||
|
|
||||||
|
Note that if you want to install it under a different directory (e.g., /opt), replace "--prefix=/usr" in configure command with something else.
|
||||||
|
|
||||||
|
$ cd git-x.x.x
|
||||||
|
$ make configure
|
||||||
|
$ ./configure --prefix=/usr
|
||||||
|
$ make all doc info
|
||||||
|
$ sudo make install install-doc install-html install-info
|
||||||
|
|
||||||
|
--------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
via: http://ask.xmodulo.com/install-git-linux.html
|
||||||
|
|
||||||
|
作者:[Dan Nanni][a]
|
||||||
|
译者:[译者ID](https://github.com/译者ID)
|
||||||
|
校对:[校对者ID](https://github.com/校对者ID)
|
||||||
|
|
||||||
|
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创翻译,[Linux中国](https://linux.cn/) 荣誉推出
|
||||||
|
|
||||||
|
[a]:http://ask.xmodulo.com/author/nanni
|
||||||
|
[1]:https://github.com/git/git/releases
|
Loading…
Reference in New Issue
Block a user