当前位置:  编程技术>移动开发
本页文章导读:
    ▪关于BACnet协议栈使用的常见有关问题回答FAQ        关于BACnet协议栈使用的常见问题回答FAQFAQ - Frequently Asked Questions about the BACnet Stack Q-1: Do you know the typical footprint of the stack (MS/TP use)? A-1a: It fits on a PIC18F6720 (128K bytes flash 3840 bytes RAM) and there is lo.........
    ▪ 应用Acitivity实现简易的音乐播放器        使用Acitivity实现简易的音乐播放器本篇使用Activity来实现一个简单的音乐播放器,提供的功能是在播放音乐的同时可以打开其他的软件,在来电是暂停播放,这里使用到的类有: android.os.Enviro.........
    ▪ Redhat Enterprise5.3上的配置文件/etc/syslog.conf解析       Redhat Enterprise5.3下的配置文件/etc/syslog.conf解析配置文件/etc/syslog.conf是系统日志文件的Deamon服务,是syslogd这个daemon的配置文件。syslogd负责产生Linux的日志文件信息,klogd负责产生linux内核信息.........

[1]关于BACnet协议栈使用的常见有关问题回答FAQ
    来源: 互联网  发布时间: 2014-02-18
关于BACnet协议栈使用的常见问题回答FAQ

FAQ - Frequently Asked Questions about the BACnet Stack

Q-1: Do you know the typical footprint of the stack (MS/TP use)?

A-1a: It fits on a PIC18F6720 (128K bytes flash 3840 bytes RAM) and there is lots of room for the application - see ports/pic18f6720 project. In one device with 8 Binary Value objects, 8 Binary Input objects, 1 Analog Input object, and supporting ReadProperty, WriteProperty, DeviceCommunicationControl, TimeSync, ReinitializeDevice, Who-Is, I-Am services, the BACnet stack used about 32K words of the code space.

A-1b: It fits on a ATmega168 (16K bytes flash, 1024 bytes RAM) - see ports/atmega168 project. The BACnet Capabilities include WhoIs, I-Am, ReadProperty, and WriteProperty support. The BACnet objects include a Device object, 10 Binary Value objects, and 10 Analog Value objects. An LED is controlled by Binary Value object instance 0. All required object properties can be retrieved using ReadProperty. The Present_Value property of the Analog Value and Binary Value objects can be written using WriteProperty. The Object_Identifier, Object_Name, Max_Info_Frames, Max_Master, and baud rate (property 9600) of the Device object can be written using WriteProperty.

With full optimization, the statistics on the demo are: IAR Atmel AVR C/C++ Compiler V5.10A/W32
12 732 bytes of CODE memory (+ 36 range fill )
955 bytes of DATA memory (+ 24 absolute ) (includes CStack=512)

avr-gcc (GCC) 4.2.2 (WinAVR 20071221rc1)
Program: 15790 bytes (96.4% Full)
Data: 414 bytes (40.4% Full) (does not include CStack=0?62)

A-1c: It fits easily on an ATmega644p (64K bytes flash, 4096 bytes RAM) - see ports/bdk-atxx4-mstp/ project. The BACnet Capabilities of an Application Specific Controller include WhoIs, I-Am, WhoHas, I-Have, ReadProperty, ReadPropertyMultiple, WriteProperty, and DeviceCommunicationControl support. The BACnet objects include a Device object, 2 Analog Input objects, 2 Analog Value objects, 5 Binary Input objects, and 2 Binary Output objects. Two LEDs are controlled by Binary Output objects. All required object properties can be retrieved using ReadProperty or ReadPropertyMultiple. Most of the Present_Value properties of the objects can be written.  The Object_Identifier, Object_Name, Max_Info_Frames, Max_Master, and baud rate (property 9600) of the Device object can be written using WriteProperty.  The APDU size is 256 bytes.

With full optimization, the statistics on this port are:
avr-gcc (GCC) 4.3.4
Program (.text+.data): 34172 bytes (52.1% Full)
Data (.data+.bss+.noinit):  2501 (61.1% Full) (not including CStack=1594 bytes)
CStack usage (from painting): 772 bytes

IAR C/C++ Compiler V5.40.2.50249/W32 for Atmel AVR
IAR Universal Linker V4.61L/W32
 28 770 bytes of CODE memory (+             8 range fill )
  3 250 bytes of DATA memory (+ 44 absolute ) (includes CStack=1024)

Q-2: The homepage used to say that the MS/TP code does not work. Still true?

A-2: MS/TP works correctly as of the 0.2.6 release. I spent a several days correcting it while working on the RTOS-32 port, and then a full day fine-tuning it while working on the PIC18F6720 that I used at the 2006 BACnet International Plugfest. I also successfully used MS/TP with the 0.4.0 release at the 2007 BACnet International Plugfest on an Atmel AVR ATmega168.

Q-3: Does the stack have some specific requirements regarding the hardware (e.g. non-volatile memory, 32-bit CPU, ...)?

A-3: Not really. The specific stuff is in the ports/ directory, and that is expected to be modified by the end user if necessary. Big Endian and Little Endian used to be automatic, but that took up too much code space, so there is a BIG_ENDIAN define in the makefile. Most of the variables are defined using the ANSI C-99 uint8_t, uint16_t, uint32_t, int8_t, int16_t, int32_t from stdint.h, along with bool from stdbool.h. Most of the APDU size returns are int.

Q-4: Does the stack have some specific requirements regarding OS? What OS features are used (threads, timers, semaphors, events, mutexes...)?

A-4: No, I did not use any OS features (except for the the ports to specific OS's: port/rtos32/, port/win32/ and port/linux/ which uses some tasks or threads for the MS/TP datalink layer or sockets for the BACnet/IP layers). Since my target was embedded, I kept every thing single-threaded (but multithread safe except where noted) to keep it easy to follow and easy to implement in a microcontroller just running a main() loop.

Q-5: What is the difference between the two datalink layers BACnet/IP and BACnet Ethernet? In BACnet/IP, is the MAC address needed?

A-5: The BACnet/IP datalink layer uses the BACnet Virtual Link Control (BVLC) for networking using UDP/IP. The IPv4 address (x.x.x.x) and the port number (0xBAC0) is stored as the MAC address. IPv6 will utilize a virtual MAC address which will be the Device ID. See Annex J or bip.c in the BACnet stack.

BACnet Ethernet uses the Ethernet MAC address, and communicates using the IEEE 802.2/802.3 (see ANSI/ASHRAE 135-2004-7 Data Link/Physical Layers: ISO 8802-3 ("Ethernet") LAN). See ethernet.c in the port/linux/ directory of the BACnet stack.

Q-6: What do I need to do to learn about BACnet? Can this project help?

A-6: Open source projects are great since they allow you to look over the internals of a program or library. However, sometimes you just want to see something work. I created about a dozen example applications for testing. One of the applications is demo/server/bacserv that acts like a BACnet server device. Run it on one PC or hardware platform, and then use the other example applications on another PC to interact with it. Monitor the BACnet network activity with the WireShark protocol analyzer. Modify the example applications - "Take chances, make mistakes, get messy." Have fun! Join the BACnet developers mailing list and ask lots of questions so others can learn and help too!

Q-7: The stack is working fine with demo/server/bacserv. But in the WireShark protocol analyzer, I am able to see only 'Who-Is' and 'I -Am' query/responses. The ReadProperty query/responses are not there in the capture viewer. Why?

A-7: If you are only able to see broadcast messages like Who-Is and I-Am, then you are probably networking using an Ethernet switch (bridge) to connect WireShark to the devices. The Ethernet switch (bridge) actually routes the unicast messages between ports and does not send them to all ports (unless configured to do so). If you use an Ethernet Hub or run WireShark from one of the devices under test, you will then see the ReadProperty messages.

Q-8: I intend to write a little program to implement the comunication between Bacnet devices and tcp/ip devices, but not use PAD and BACnet/IP. Can I do that in a standard way?

A-8: You describe what the BACnet committee just published recently: Addendum 135-2004c, BACnet Web Services, which has been approved by ASHRAE and ANSI.

I don't have web services implemented in the BACnet stack at SourceForge, but you could certainly use the stack do so.

Q-9: How do I create the required objects (analog inputs, analog outputs, binary inputs, binary outputs) to support the hardware on my board?

A-9: See the example application demo/server for an example of a server application with objects included. The simple answer is that they exist in the Device object in the Object_List property. Every BACnet device is required to have a Device Object, and one of the required properties is the Object_List property.

The example objects are in demo/object and those that are included in the device are in demo/object/device.c as defined in 5 locations in the file. For each object type:

       1. #include the header file for the object
       2. Device_Object_List_Count() needs to include a call to a count function from the object type.
       3. Device_Object_List_Identifier() needs to include some code to get the object instance for each object.
       4. Device_Valid_Object_Id() needs to get the object name for each object.
       5. PROP_PROTOCOL_OBJECT_TYPES_SUPPORTED needs to set a bit for each object type supported.

Additionally, for each service that interacts with objects, you will need to include handling for that object. See demo/handler/h_rp.c to see how the different objects are accessed for the ReadProperty service. See demo/handler/h_wp.c to see how the different objects are accessed for the WriteProperty service. If those are the only services that you are going to use, then most of the work has been done other than selecting which object types you are going to support.

As for how many of what object, see the individual object files for examples of how that works (see demo/object directory). Also note that there are optional properties of some objects that may or may not have an example included in this demo code. For example, a Binary Value object optionally includes a Priority_Array. There is an example in the demo/object that includes a Priority_Array, and an example in ports/pic18f6720 that does not have the Priority_Array.

You can read/write to the properties using demo/readprop and demo/writeprop example client applications that run under Windows or Linux command line.

Q-10: Since each Device object must have an object identifier that is unique internetwork-wide, how is this ID determined?

A-10: Device object instance number is normally configured on site after the device is installed. Therefore, the Device object instance number should be configurable between 0 and 4194303 inclusive (see bacdef.h for BACNET_MAX_INSTANCE). If your hardware does not have any user interface, you can have the device default to 4194303 and implement WriteProperty service to the Object_Identifier of the Device object. You could also have some other method for configuring the Device Object instance number such as an RS-232 terminal interface or HTTP screen configuration like a home internet router.

Note that 4194303 is known as "unconfigured" and is not really a valid device instance number. Also, all devices are required to respond with their own Device object instance number when 4194303 is requested.

Q-11: For the objects supported by the device, they are required to be unique within the BACnet device that maintains them. Can I start with an object instance number of 0 or 1 and increment accordingly for each new object created within the device?

A-11: For each object type, you can create any object instance numbers between 0 and 4194302 inclusive. How you choose to number them is up to you.

In the example object in demo/object/ I numbered them sequentially starting at 0. If you do choose to use some other numbering scheme, be sure to update the Index_To_Instance(), Valid_Instance(), Count(), and Name() functions of each object type to correctly handle your numbering scheme.

Q-12: For the object names, do you really use AV-## or ANALOG VALUE # in your system? All of our AV values have unique names like "ACTIVE_ALARM", "REVISION", "DUCT_STATIC".

A-12: As long as your names are unique in your device (i.e. no duplicate names) you can use your names. In the demo objects, I just use "AV-1" or "ANALOG VALUE 1" as the Object_Name where 1 is the object instance number. Update the Name() function for each object type if you change from the default names.

Q-13: I need to have about 100 Analog Value objects and 100 Binary Value objects in my device. When I try to define over 15 objects I get a memory error from the PIC compiler. What is the problem?

A-13: If you are using the unmodified Analog Value or Binary Value objects from demo/objects, they include a priority array. That means that each object has 16 Present_Values stored for each object, plus an Out_Of_Service status. Each object would consume about 17 bytes. 15*17=255 bytes. Limit for udata = 255 bytes on the PIC using the Microchip compiler.

Output and value objects are not required to have Out_Of_Service writable. Value objects are not required to have a priority array. If you need or want to have priority arrays for your objects, then you might consider storing the Binary Value object Present_Value in some smaller form (currently it is stored as enumeration which consumes a byte on a PIC). There are Binary Value and Analog Value object examples that do not include a priority array in the ports/pic18f6720/ directory.

Q-14: What do I have to do to reduce the size of the firmware made from this BACnet stack?

A-14: Here are the things that you can do to shrink the firmware size:

       1. For MS/TP, change the state machine to use a fixed memory structure rather than a pointer to a structure. Some microcontroller compilers generate more code when having to dereference the structure. This limits you to a single MS/TP datalink.
       2. Remove unused services by
              * remove the service C file from the makefile
              * remove the function call to setup the service
              * remove the service handler
       3. Remove unnecessary objects by:
              * Remove the demo/object C file from the makefile
              * remove function calls to the demo/object C file.
              * Change the number of objects that you have.
              * Only a Device object is required.
              * Update the Device object PROP_PROTOCOL_OBJECT_TYPES_SUPPORTED
       4. Remove unused function calls by:
              * #if 0 and #endif around the unused functions (especially in bacdcode.c)
              * Compile and Link. If the linker fails, then that function was needed.
              * Some compilers, like GCC, have garbage collection for unused functions and code. If enabled, the linker will eliminate the unused functions and code. Use the GCC compiler and linker directive to enable this feature.

Q-15: I have downloaded the BACnet stack but can't get demo/server to work. I am using a single computer. In one console window I run demo/server/bacserv. In another console window I run demo/whois/bacwi. When I capture packets with WireShark, I see the I-Am broadcast packet being sent by demo/server/bacserv when it starts. I also see the Who-Is broadcast packet sent by demo/whois/bacwi. But demo/server/bacserv never receives any message. How do I make it work?

A-15: This is a common issue with BACnet/IP. The server application binds to the BACnet/IP UDP port 47808 on that computer, and therefore, the client application is unable to receive broadcast messages on port 47808 since those packets are only going to the server application.

The correct solution is to use BVLC (BACnet Virtual Link Control) where the client applications use BACnet Foreign Device Registration, and some application (probably the server) runs a BBMD (BACnet Broadcast Management Device).

You can do one of the following:

   1. Use QEMU or Bochs or VMWare or some other virtual machine to simulate another computer, and run server or client on a virtual computer.
   2. Use the BACnet/IP BACnet Virtual Link Control (BVLC) features. The client demo applications are configured to use environment variables to establish a BBMD connection as a foreign device. Set the BACNET_BBMD_PORT and BACNET_BBMD_ADDRESS of the BBMD, and use a non-standard BACNET_IP_PORT value. Note that the demo/server application is configured as a BBMD, and there are helper scripts /bin/bvlc.sh or bin/bvlc.bat to assist.
   3. Write npdu router code to route from BACnet/IP to another datalink layer. Make server application on one datalink layer and make client applications on another datalink layer.
   4. Add external BACnet router or BACnet devices. Run a BACnet demo/server on another PC.

Q-16: My Linux computer doesn't use eth0 for for the BACnet connection. My Windows computer has more than one network connnection. How can I choose the interface to use for the demo applications?

A-16: Set the environment variable BACNET_IFACE. For Windows, set BACNET_IFACE=169.254.119.240 or whatever the address of the interface returned by ipconfig command. For Linux, use BACNET_IFACE=eth0 or whatever the name of the interface returned by the ifconfig command. Setting the environment variable under Windows can be done on the command line:

> set BACNET_IFACE=169.254.119.240

Setting the environment variable under Linux can be done from the command line:

$ BACNET_IFACE=ath0
$ export BACNET_IFACE

Q-17: I need to communicate with an MS/TP Slave Node. Can I configure the demo applications to use a static address binding?

A-17: Yes, static address binding is supported as of version 0.4.3. Use a file called address_cache (which is defined in src/address.c). The file format is record based as follows:
;DeviceID MAC SNET SADR MAX-APDU
4194302 05 0 0 50
55555 C0:A8:00:18:BA:C0 26001 19 50


    
[2] 应用Acitivity实现简易的音乐播放器
    来源: 互联网  发布时间: 2014-02-18
使用Acitivity实现简易的音乐播放器

本篇使用Activity来实现一个简单的音乐播放器,提供的功能是在播放音乐的同时可以打开其他的软件,在来电是暂停播放,这里使用到的类有:

android.os.Environment  读取系统存储目录的文件

android.media.MediaPlayer 系统媒体播放器

android.telephony.TelephonyManager  电话管理器

android.telephony.PhoneStateListener  电话状态监听器


我们知道如果不做任何处理,在Activity播放音乐的时候,去打开了另外一个Activity,音乐播放器会仍然播放,因为它没有被摧毁,但是当我们点击模拟器的返回键后,它就会回调onpause()--->onStop()-->onDestroy()方法,此时Activity已经被销毁,我们可以在onPause()方法中来保存进度,然后再onResume()方法中来恢复播放进度。

本实例实现的是播放音乐的同时可以打开其他的软件,当有来电就暂停播放,当电话挂断了就继续播放,这里需要用到的一个权限来监听电话的状态:<uses-permission android:name="android.permission.READ_PHONE_STATE"/>


播放音乐的Activity界面:


当我们点击打开一个activity后,音乐播放器并没有停止(这个不用做任何处理)。

以下是源代码:

main.xml:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:orientation="vertical" >

    <TextView
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:text="音乐播放器" />
	<EditText 
	    android:id="@+id/filename"
	    android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:text="pugongying.mp3"/>
	
	<LinearLayout 
	    android:layout_width="fill_parent"
	    android:layout_height="fill_parent"
	    android:orientation="horizontal" >
	    <Button 
	        android:id="@+id/playButton"
		    android:layout_width="wrap_content"
	        android:layout_height="wrap_content"
	        android:text="@string/playButton"
	        android:onClick="mediaplay"/>
	    <Button 
	        android:id="@+id/pauseButton"
		    android:layout_width="wrap_content"
	        android:layout_height="wrap_content"
	        android:text="@string/pauseButton"
	        android:onClick="mediaplay"/>
	    <Button 
	        android:id="@+id/resetButton"
		    android:layout_width="wrap_content"
	        android:layout_height="wrap_content"
	        android:text="@string/resetButton"
	        android:onClick="mediaplay"/>
	    <Button 
	        android:id="@+id/stopButton"
		    android:layout_width="wrap_content"
	        android:layout_height="wrap_content"
	        android:text="@string/stopButton"
	        android:onClick="mediaplay"/>
	    <Button 
		    android:layout_width="wrap_content"
	        android:layout_height="wrap_content"
	        android:text="打开一个activity"
	        android:onClick="openActivity"/>
	</LinearLayout>
</LinearLayout>

values/String.xml

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <string name="hello">Hello World, MainActivity!</string>
    <string name="app_name">Android_Music</string>
    <string name="playButton">播放</string>
    <string name="pauseButton">暂停</string>
    <string name="resetButton">重播</string>
    <string name="stopButton">停止</string>
    <string name="continues">继续</string>
</resources>


MainActivity.java

package com.music.activity;

import java.io.File;
import java.io.IOException;
import android.app.Activity;
import android.content.Context;
import android.content.Intent;
import android.media.MediaPlayer;
import android.media.MediaPlayer.OnPreparedListener;
import android.os.Bundle;
import android.os.Environment;
import android.telephony.PhoneStateListener;
import android.telephony.TelephonyManager;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;

public class MainActivity extends Activity {
	private static String TAG = "MainActivity";
	private EditText nameText;	//mp3文件名称
	private String path;	//文件路径
	private MediaPlayer mediaPlayer;
	private boolean pause;	//暂停标志
	private int position;	//播放进度
    @Override
    public void onCreate(Bundle savedInstanceState) {
    	Log.i(TAG, "onCreate()");
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        mediaPlayer = new MediaPlayer();
        nameText = (EditText)findViewById(R.id.filename);
        TelephonyManager telephonyManager = (TelephonyManager)getSystemService(Context.TELEPHONY_SERVICE);
        telephonyManager.listen(new MyPhoneListener(), PhoneStateListener.LISTEN_CALL_STATE);
    }
    
	@Override
	protected void onDestroy() {
		Log.i(TAG, "onDestroy()");
    	mediaPlayer.release();
    	mediaPlayer = null;
    	super.onDestroy();
	}

	//电话状态监听器
    private final class MyPhoneListener extends PhoneStateListener{
		@Override
		public void onCallStateChanged(int state, String incomingNumber) {
			switch (state) {
			case TelephonyManager.CALL_STATE_RINGING:
				if(mediaPlayer.isPlaying()){
					position = mediaPlayer.getCurrentPosition();
					mediaPlayer.stop();
				}
				break;
			case TelephonyManager.CALL_STATE_IDLE:
				if(position>0 && path!=null){
					play();
					mediaPlayer.seekTo(position);
					position = 0;
				}
			default:
				break;
			}
		}
    }

	public void mediaplay(View v){
    	switch (v.getId()) {
		case R.id.playButton:
			String fileName = nameText.getText().toString();
			File audio = new File(Environment.getExternalStorageDirectory(),fileName);
			if(audio.exists()){
				path = audio.getAbsolutePath();
				play();
			}else{
				Toast.makeText(getApplicationContext(), fileName+"不存在", 1).show();
			}
			break;
		case R.id.pauseButton:
			if(mediaPlayer.isPlaying()){
				mediaPlayer.pause();
				pause = true;
				((Button)v).setText(R.string.continues);
			}else{
				if(pause){
					mediaPlayer.start();	//继续播放
					pause = false;
					((Button)v).setText(R.string.pauseButton);
				}
			}
			break;
		case R.id.resetButton:
			if(mediaPlayer.isPlaying()){
				mediaPlayer.seekTo(0);	//播发进度置0
			}else{
				if(path!=null){
					play();
				}
			}
			break;
		case R.id.stopButton:	
			if(mediaPlayer.isPlaying())
				mediaPlayer.stop();
			break;
		}
    }
    //播放媒体文件
	private void play() {
		try {
			mediaPlayer.reset();	//重置各项参数
			mediaPlayer.setDataSource(path);
			mediaPlayer.prepare();	//进行数据缓冲
			mediaPlayer.setOnPreparedListener(new PreparedListener());
			
		} catch (IllegalArgumentException e) {
			e.printStackTrace();
		} catch (IllegalStateException e) {
			e.printStackTrace();
		} catch (IOException e) {
			e.printStackTrace();
		}
	}
	//监听缓冲完毕事件
	private final class PreparedListener implements OnPreparedListener{
		//缓冲完毕回调该方法
		@Override
		public void onPrepared(MediaPlayer mp) {
			mediaPlayer.start();;	//开始播放
		}
		
	}
	public void openActivity(View v){
		Intent intent = new Intent(MainActivity.this,OtherActivity.class);
		startActivity(intent);
	}
}


AndroidManifest.xml

<activity android:name=".OtherActivity"/>

<uses-permission android:name="android.permission.READ_PHONE_STATE"/>


    
[3] Redhat Enterprise5.3上的配置文件/etc/syslog.conf解析
    来源: 互联网  发布时间: 2014-02-18
Redhat Enterprise5.3下的配置文件/etc/syslog.conf解析

配置文件/etc/syslog.conf是系统日志文件的Deamon服务,是syslogd这个daemon的配置文件。syslogd负责产生Linux的日志文件信息,klogd负责产生linux内核信息日志文件。

典型的syslog.conf文件的内容如下:

/etc/syslog.conf文件

# Log all kernel messages to the console.
# Logging much else clutters up the screen.kern内核产生信息的地方
kern.*                            /dev/console  

# Log anything (except mail) of level info or higher.
# Don't log private authentication messages!
*.info;mail.none;news.none;authpriv.none;cron.none        /var/log/messages

# The authpriv file has restricted access.authpriv主要与认证有关的机制,例如login,ssh,su等需要账号/密码
authpriv.*                        /var/log/secure

# Log all the mail messages in one place. mail与邮件首发有关的信息记录
mail.*                            -/var/log/maillog


# Log cron stuff cron例行性工作调度cron/at等生成信息日志的地方
cron.*                            /var/log/cron

# Everybody gets emergency messages 将任何设备的emerg级别的信息发送给所有正在系统上的用户。
*.emerg                            *

# Save news errors of level crit and higher in a special file. 将uucp和news设备的crit级别的信息记录到/var/log/spooler文件中
uucp,news.crit                        /var/log/spooler

# Save boot messages also to boot.log  启动过程信息记录
local7.*                        /var/log/boot.log

#
# INN
#news与新闻组服务器有关的东西
news.=crit                                        /var/log/news/news.crit
news.=err                                         /var/log/news/news.err
news.notice                                       /var/log/news/news.notice
--------------------------end------------------------------------------

/etc/syslog.conf根据如下的格式定义规则:

facility.level  action

 

设备.优先级 动作facility.level 字段也被称为seletor(选择条件),选择条件和动作之间用空格或tab分割开。
#号开头的是注释,空白行会自动跳过。

 

syslog设置的服务(facility)主要包括以下:

authpriv -包括特权信息如用户名在内的认证活动
cron -与 cron 和 at 有关的计划任务信息。
daemon -与 inetd 守护进程有关的后台进程信息。
kern -内核信息,首先通过 klogd 传递。
lpr -与打印服务有关的信息。
mail -与电子邮件有关的信息
mark - syslog内部功能用于生成时间戳
news -来自新闻服务器的信息
syslog -由 syslog 生成的信息
user -由用户程序生成的信息
uucp -由 uucp 生成的信息
local0-local7 -与自定义程序使用


 

level定义消息的紧急程度。按严重程度由高到低顺序排列为:emerg -该系统不可用,等同panic
alert -需要立即被修改的条件
crit -阻止某些工具或子系统功能实现的错误条件
err -阻止工具或某些子系统部分功能实现的错误条件,等同error
warning -预警信息,等同warn
notice -具有重要性的普通条件
info -提供信息的消息
debug -不包含函数条件或问题的其他信息
none -没有重要级,通常用于排错


    
最新技术文章:
▪Android开发之登录验证实例教程
▪Android开发之注册登录方法示例
▪Android获取手机SIM卡运营商信息的方法
▪Android实现将已发送的短信写入短信数据库的...
▪Android发送短信功能代码
▪Android根据电话号码获得联系人头像实例代码
▪Android中GPS定位的用法实例
▪Android实现退出时关闭所有Activity的方法
▪Android实现文件的分割和组装
▪Android录音应用实例教程
▪Android双击返回键退出程序的实现方法
▪Android实现侦听电池状态显示、电量及充电动...
▪Android获取当前已连接的wifi信号强度的方法
▪Android实现动态显示或隐藏密码输入框的内容
▪根据USER-AGENT判断手机类型并跳转到相应的app...
▪Android Touch事件分发过程详解
▪Android中实现为TextView添加多个可点击的文本
▪Android程序设计之AIDL实例详解
▪Android显式启动与隐式启动Activity的区别介绍
▪Android按钮单击事件的四种常用写法总结
▪Android程序设计之AIDL实例详解 iis7站长之家
▪Android实现Back功能代码片段总结
▪Android实用的代码片段 常用代码总结
▪Android实现弹出键盘的方法
▪Android中通过view方式获取当前Activity的屏幕截...
▪Android提高之自定义Menu(TabMenu)实现方法
▪Android提高之多方向抽屉实现方法
▪Android提高之MediaPlayer播放网络音频的实现方法...
▪Android提高之MediaPlayer播放网络视频的实现方法...
▪Android提高之手游转电视游戏的模拟操控
 


站内导航:


特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

©2012-2021,,E-mail:www_#163.com(请将#改为@)

浙ICP备11055608号-3