http://www.cnblogs.com/smarterplanet/p/4658704.html
修改之后的jwplayer源码下载。
JWPlayer的API
http://support.jwplayer.com/customer/portal/topics/564475-javascript-api/articles
https://developer.jwplayer.com/jw-player/docs/javascript-api-reference/
Braodcast from android handset with the help of Rtsp Server from VXG (Google player)
IP: 172.24.1.168 Port: 5540
Resolution: 720X480
Bitrate: Video=1000 kpbs, Audio=64 kpbs
URL = rtsp://172.24.1.168:5540/ch0
Streaming Server:
Debian 8 with crtmpserver v1.1c
IP = 172.24.1.69
Enable RTSP source by add following definition in the externalStreams section of crtmpserver.lua:
externalStreams ={
   {
     uri=”rtsp://172.24.1.168:5540/ch0″,
     localStreamName=”rtsp”,
     forceTcp=true,
     keepAlive=true
     },
}
Verify RTMP on Workstation :
ffplay rtmp://172.24.1.69/live/rtsp
Support rtmp and rtsp same time from crtmpserver
Enable rtsp inbound in accept section of config file:
acceptors =
 {
    {
    ip=”0.0.0.0″,
    port=6666,
    protocol=”inboundLiveFlv”,
    waitForMetadata=true,
   },
   {
   ip=”0.0.0.0″,
   port=9999,
   protocol=”inboundTcpTs”
   },
  {
   ip=”0.0.0.0″,
   port=5544,
   protocol=”inboundRtsp”
   },
}
Verify RTSP on Workstation :
ffplay rtsp://172.24.1.69:5544/rtsp
http://www.cnblogs.com/zjoch/p/3277198.html
Configuration file
配置文件
The configuration file is actually a lua script which must contain an
object called configuration.
This will be read by the server and used to fully configure the server.
Besides this object called
configuration you can have functions, include other lua libraries, etc.
In the end, you have to
make the configuration object available. The rest of this section will
explain the structue of
configuration object in great detail. But first, let’s take an bird-eye
view.
配置文件实际上是一个Lua脚本,它包含至少一个configuration的对象,
从而为程序提供灵活的扩展和定制功能。
除了configuration对象外,还可以有函数,Lua库等。
configuration=
{
daemon=false,
pathSeparator=”/”,
logAppenders=
{
— content removed for clarity
},
applications=
{
— content removed for clarity
}
}
configuration structure
key type mandatory description
daemon boolean yes true means the server will start in daemon mode.
false means it will start in console mode (nice for development)
true 表示 服务以后台方式启动;
false 表示 服务以控制台模式启动(以用于开发);
pathSeparator string(1) yes This value will be used by the server to
compose paths (like media files paths).
Examples: on UNIX-like systems this is / while on windows is \.
Special care must be taken when you specify this values on windows
because \ is an escape sequence for lua so the value should be “\\”
用来分隔路径;
例如,在UNIX-like是 /, Windows是 \ ;
logAppenders object yes Will hold a collection of log appenders. Each
of log messages will pass through all the log appenders enumerated here.
More details below
配置日志追加的容器 <http://wiki.rtmpd.com/documentation#logappenders>
applications object yes Will hold a collection of loaded applications.
Besides that, it will also hold few other values. More detailsbelow
配置加载各种应用的容器 <http://wiki.rtmpd.com/documentation#applications>
When the server starts, the following sequence of operations is performed:
服务启动时,将按顺序执行下列操作:
1.
The configuration file is loaded. Part of the loading process, is
the verification.
If something is wrong with the syntax please read this
配置文件加载后,首先做的就是对配置文件进行校验,
如果配置文件有错误,将会有错误提示并停止启动,可进行修改后再启动
<http://wiki.rtmpd.com/faq#qi_run_server_but_it_silently_shutdown_what_is_wrong>
2.
daemon value is read. The server now will either fork to become daemon
or continue as is in console mode
读取 daemon 值,判断服务是以后台方式启动还是以控制台方式启动
3.
logAppenders is read. This is where all log appenders are configured
and brought up to running state.
Depending on the collection of your log appenders, you may (not) see
further log messages
读取日志追加器,用来配置日志记录并启动到运行状态,
依据日志追加器,可以看到更多的日志信息
4.
applications is taken into consideration. Up until now, the server
doesn’t do much.
After this stage completes, all the applications are fully
functional and the server is online and ready to do stuff
最后的应用加载,只到这一步完成后,服务和应用才在线,并准备就绪。
日志追加器
logAppenders
This section contains a list of log appenders. The entire collection of
appenders listed in this section
is loaded inside the logger at config-time. All log messages will be
than passed to all this log appenders.
Depending on the log level, an appender may (not) log the message.
“Logging” a message means “saving”
it on the specified “media” (in the example below we have a console
appender and a file).
这部分包含了一个日志追加器的列表。
整个日志追加器的添加是在加载时配置,
依据日志级别,追加器可以选择是否有日志消息输出到指定目的处;
logAppenders=
{
{
name=”console appender”,
type=”coloredConsole”,
level=6
},
{
name=”file appender”,
type=”file”,
level=6,
fileName=”/tmp/crtmpserver.log”
}
},
logAppenders structure
key type mandatory description
name string yes The name of the appender. Is usually used inside
pretty print routines
追加器的名字.
type string yes The type of the appender. It can
be console, coloredConsole or file. console and
coloredConsole will output to console. The difference between them is
that coloredConsole
will also apply a color to the message, depending on the log level.
Quite useful when eye-balling the console.
file log appender will output everything on the specified file
追加器的类型
可以是控制台,带颜色控制台或文件;
控制台和带颜色控制台 都会将日志消息输出到控制台,
不同之处在于带颜色控制台会依据日志级别进行颜色标记;
文件类型则会将所有消息输出到指定的文件;
level number yes The log level used. The values are presented just
below. Any message having having a log level
less or equal to this value will be logged. The rest are discarded.
Example: setting level to 0, will only log FATAL errors.
Setting it to 3, will only log FATAL, ERROR, WARNING and INFO
日志的级别
可见下表中的级别定义;
只有小于或等于这个级别的日志消息会被记录,高于这个级别则都被丢弃;
例如:
级别为0时,只记录 FATAL 消息;
级别为3时,只记录 FATAL, ERROR, WARNING, INFO 消息;
fileName string yes If the type of appender is a file, this will
contain the path of the file
如果追加器类型为文件,则在此处指定日志文件和路径
Log levels
Name Value
0 FATAL
1 ERROR
2 WARNING
3 INFO
4 DEBUG
5 FINE
6 FINEST
Observation: When daemon mode is set to true, all console appenders will
be ignored.
(Read the explanation for daemon setting here
<http://wiki.rtmpd.com/documentation#main_structure>)
注意:
当使用后台模式时,所有的控制台追加消息将会被忽略。
应用
Applications
This section is where all the applications inside the server are placed.
It holds the attributes of each application that the server will use to
launch them.
Each application may have specific attributes that it requires to
execute its own functionality.
这部分用来配置各种应用,并设置这些应用的属性;
每个应用的属性都对应了这个应用的指定功能;
applications=
{
rootDirectory=”applications”,
{
— settings for application 1
— content removed for clarity
},
{
— settings for application 2
— content removed for clarity
},
{
— settings for application 3
— content removed for clarity
}
}
Applications Structure
key type mandatory description
rootDirectory string true The folder containing applications
subfolders. If this path begins with a / or \ (depending on the OS),
than is treated as an absolute path. Otherwise is treated as a path
relative to the run-time directory
(the place where you started the server)
这个目录包含了应用的子目录;
如果路径以 / 或 \ 开始, 则视其为绝对路径,否则视为启动服务时所在的相对
路径;
Following the rootDirectory, there is a collection of applications. Each
application has
its properties contained in an object. See details below
rootDirectory 之后,是应用的集合;每个应用都定义了一个有特定属性的对象;
细节如下所示; <http://wiki.rtmpd.com/documentation#application_definition>
应用定义
Application Definition
This is where the settings of an application are defined. We will
present only the
settings common to all applications. Later on, we will also explain the
settings particular to certain
applications Since revision 790 there is a new cool feature:
mediaStorage; with this feature
basicaly an application may have multiple mediaFolder’s and .seek/.meta
files are now stored into
separate folder from media file that are streamed.
这些目录用来定义应用.
自从790版本后,添加了一新的功能:mediaStorage;
这个功能能使应用可以有多个mediaFolder,
并且可以将.seek/.meta文件和媒体文件分开存储在不同的文件夹中;
{
name=”flvplayback”,
protocol=”dynamiclinklibrary”,
description=”FLV Playback Sample”,
default=false,
validateHandshake=true,
enableCheckBandwidth=true,
— this settings are now part of mediaStorage setting
— keyframeSeek=true,
— seekGranularity=1.5,
— clientSideBuffer=12,
— generateMetaFiles=true,
— renameBadFiles=true,
aliases=
{
“simpleLive”,
“vod”,
“live”,
“WeeklyQuest”,
“SOSample”,
“oflaDemo”,
“chat”,
},
acceptors =
{
{
— acceptor 1
— content removed for clarity
},
{
— acceptor 2
— content removed for clarity
},
{
— acceptor n
— content removed for clarity
},
},
— new feature mediaStorage
mediaStorage = {
namedStorage1={
description=”Main storage”,
mediaFolder=”/usr/main_storage/media”, — only this parameter IS
MANDATORY
metaFolder=”/usr/main_storage/metadata”, — if you have static
large file to stream it is good to know that for a file around 500MB
— it’s .seek file has
around 16MB; so it would be preffer to designate metafolder into a system
— partition which has
enough space… for no surprises… 🙂
statsFolder=”/usr/main_storage/statsFolder”,
enableStats=true,
clientSideBuffer=16,
keyframeSeek=false, — should crtmpdserver DO SEEK ONLY IN
key-frame (true/false)?
— very useful to know in situations like
play/pause/resume (meaning pause/seek/play)
seekGranularity=1,
generateMetaFiles=false,
renameBadFiles=false,
},
–[[{
— here is another example of storage; it does not start with
name={…}
description=”Second storage of same application”,
mediaFolder=”/usr/second_storage/media/flv”,
metaFolder=”/usr/second_storage/metadata”,
statsFolder=”/usr/second_storage/statsFolder”,
},]]–
},
externalStreams =
{
{
— stream 1
— content removed for clarity
},
{
— stream 2
— content removed for clarity
},
{
— stream n
— content removed for clarity
},
},
authentication=
{
— content removed for clarity
}
}
Application Structure
key type mandatory description
name string yes Name of application.
应用的名称
protocol string yes Type of application. The
value dynamiclinklibrary means the application is a shared library.
应用的类型
值为 dynamiclinklibrary 意即 应用是一个共享库
description string no You can put a description of the application here.
应用的描述信息
default boolean no This flag designates the default application.
The default application is responsible in analyzing the connectrequest
and distribute the future connection to the correct application.
这个标志指定了默认应用;
默认应用负责分析连接请求并将连接分配到正确的应用
validateHandshake boolean no Tells the server to validate the
client’s handshake before going further.
This is optional with a default value of true. If this is true and the
handshake fails,
the connection is dropped. If this is false, handshake validation will
not be enforced
and all the connections are accepted no matter if they are correctly
hand shaking or not.
通知服务器在进行下一步前要对客户端的握手进行验证;
这是一个可选项,其默认值为真。
如果这个值为真 且 握手失败,服务器就放弃这个连接。
如果这个值为假,则不会进行强制的握手验证,所有的连接都会被接受;
keyframeSeek boolean no This instructs the streamer to seek only on
key frames. In case of live streaming, this is discarded.
这个属性指定了流生成器只在关键帧搜索,
如果是直播流,则忽略这个值
seekGranularity double no The seek resolution/granularity value in
seconds. Values are between 0.1 and 600.
For example, if granularity is 10 seconds, and a seek to t=2:34 is
desired, the seek
will actually go to t=2:30.
60seconds is recommended for full length movies and 1 second for video
clips.
搜索的精细度,以秒为单位, 值域定义在 0.1 ~ 600;
例如:
如果粒度定义为10秒,并期望定位到 t= 2:34;
则实际上是会定位到 t= 2:30.
60秒被认定为完整的电影长度,1秒为电影片断;
clientSideBuffer double no The amount of client side buffer that will
be maintained for each connection.
Values are between 5 and30 seconds.
每个连接在客户端的缓冲秒数,值定义在5 ~ 30 秒;
generateMetaFiles boolean no This will generate seek/meta files on
application startup.
在应用启动前生成 seek/meta文件
renameBadFiles boolean no If this flag is true and the media file
can’t be parsed, the media file will be renamed to *.bad.
Otherwise it will be left alone.
如果这上值为真且媒体文件是不能被解析的,则媒体文件被重命名为 *.bad,
否则这样的文件将不做处理
aliases object no The application will also be known by this name.
应用的别名
acceptors object no Acceptors hold the service that will be hosted to
the server. An application can have its own acceptor,
but this is not entirely required, and can be optional.
接受器保持这个服务并让服务器托管;
应用可以有它自己的接受器,但这个是可选的;
externalStreams object no
authentication object no
mediaFolder string yes When define mediaStorage this field is
mandatory as it points out physical location of media files.
当定义了 mediaStorage时,这个域用来指定媒体文件的物理位置;
metaFolder string no It holds the location where .seek/.meta files
created from files inside mediaFolder are stored.
指定用来存放 .seek/.meta文件的位置;
statsFolder string no Location for stats files.
服状态文件的位置
Acceptor Structure
key type mandatory description
ip string yes The IP where the service is located. 0.0.0.0 means all
interfaces and all IPs.
服务所在的IP, 0.0.0.0表示所有接口和所有IP;
port string yes Port number that the service will listen to.
服务监听的端口号
protocol string yes The protocol stack handled by
the ip:port combination.
对应 ip:port的服务的协议
Media Player:
https://docs.peer5.com/overview/#client-side-integration
Nignx:
Let nginx support RTMP streaming, & HLS
Let nginx support seek in mp4 file, with timestamp included in mp4
做一款仿映客的直播App?看这篇就够了
http://www.cocoachina.com/ios/20160721/17133.html
http://pclosmag.com/html/Issues/201104/page19.html
Today, technology goes forward and we get some new possibilities. TV broadcasting doesn’t lose time and goes forward too. Today, you can watch online TV and watch TV programs on demand. But what if you want to record them? Don’t worry – some programs and live broadcasting (not all yet) can be recorded.
If you are not so young, then you can remember the VCR (video cassette recorder) era. You could turn on your video recorder, push the “Record” button, stop it after some time and after rewinding the tape you could play a recorded program on your TV. So what does the computer era offer?
Today, TV broadcasting via internet goes in many popular stream formats and protocols.
You have certainly heard about such streaming formats:
There are also various streaming protocols. Examples of streaming protocols:
Let’s take a look at services which are broadcasting in the RTMP protocol. What is it? Wikipedia says: “Real Time Messaging Protocol (RTMP) was initially a proprietary protocol developed by Macromedia for streaming audio, video and data over the Internet, between a Flash player and a server. Macromedia is now owned by Adobe, which has released the specification of the protocol for public use.”
So if your favorite online service (TV or video archive) uses the RTMP protocol you have a good chance of being able to save its video stream as a file on your local drive. There is an excellent utility for recording streams broadcasting TV and video on demand. This utility is called “rtmpdump.” What is it? “rtmpdump” is a console toolkit for RTMP streams. Does the word “console” mean advantage or disadvantage in this case? I think it is big advantage for such a tool. Its operating principle is simple: you input the name of a command with some options, which include the address of the video server, and get a desirable file containing the recorded TV program. You will see no graphical input on the screen, nor other useless information. It just connects to the server, consuming only the network traffic containing the video, and records it to your hard disk. If you know about the powerful “wget” utility, then you can imagine what it is like.
It’s time to start. To have “rtmpdump” in your operational system, you should install the package having the same name from the repository. This package goes with another utility, which is called “rtmpsuck.” This tool can also record video stream, but we will use it as auxiliary tool to find options for “rtmpdump.”
In order to use “rtmpsuck,” we need some preparation. “rtmpsuck” is a local RTMP proxy server which passes traffic into the internet through itself, detecting the flowing RTMP protocol and it’s parameters. “rtmpsuck” goes with no parameters. So if you run “rtmpsuck” you can only see:
RTMP proxy server … … Streaming on rtmp://0.0.0.0:1935
What that says is that the server is running and listening on port 1935. It’s necessary to notice that port 1935 is a default port of RTMP servers. But in this case, “rtmpsuck” is useless. Why? Because to make it work, you need to redirect RTMP traffic to a proxy server, which in turn will help us to know the connection parameters to the media server. To do this, you need to run the following command as a “root”:
iptables -t nat -A OUTPUT -p tcp --dport 1935 -m owner \! --uid-owner root -j REDIRECT
The meaning of this command is to add a new rule in the table controlling your network traffic in order to redirect outbound TCP traffic flowing to the default RTMP external server port (1935) to a local RTMP proxy server, except traffic which belongs to root. So, if you now open a page in you browser to watch a media stream, your traffic will flow via the proxy server, and “rtmpsuck” will provide you information which can be used in “rtmpdump.” After getting all the information, you can close “rtmpsuck” (Ctrl+C) and must remove the “iptabels” rule which you added before:
iptables -t nat -D OUTPUT -p tcp --dport 1935 -m owner \! --uid-owner root -j REDIRECT
Step 1 Run as a root in terminal:
iptables -t nat -A OUTPUT -p tcp --dport 1935 -m owner \! --uid-owner root -j REDIRECT
Step 2 Run as a root in terminal:
rtmpsuck
Step 3 As an ordinary user, open in Firefox this address: http://rt.com/on-air/rt-america-air/
Step 4 Switch to root’s terminal. You should see something like the following:
app: live flashVer: LNX 10,1,82,76 swfUrl: http://rt.com/s/swf/player5.4.viral.swf tcUrl: rtmp://rt.fms.visionip.tv/live pageUrl: http://rt.com/on-air/rt-america-air/ Playpath: RT_US_3
Break the command after a while (Ctrl+C).
Depending on your connection quality, you can get different meanings of the option “Playpath”.
You can change the options of video quality by using the following entries after the command Playpath:
RT_US_3 – high RT_US_2 – medium RT_US_1 – low
Step 5 Run the command in root terminal:
iptables -t nat -D OUTPUT -p tcp --dport 1935 -m owner \! --uid-owner root -j REDIRECT
Step 6 Run the command in terminal as an ordinary user:
rtmpdump -r rtmp://rt.fms.visionip.tv/live \ -a live \ -y RT_US_3 \ -W http://rt.com/s/swf/player5.4.viral.swf \ -p http://rt.com/on-air/rt-america-air/ \ -f "LNX 10,1,82,76" \ -o ~/rt.flv \ -V \ -B 600
After 10 minutes, you will get the video file “rt.flv” in your home directory which you can play in your favorite media player.
You can know what these parameters mean if you run the manual of command “rtmpdump”:
man rtmpdump
Option -V is just verbose, turn it off if your test recording is passed.
Exercise 1: If you live in Europe or Asia (or if it is just convenient to you), you can try to get the parameters for main broadcasting. Firefox address is http://rt.com/on-air/
Repeat steps 1 through 5 for address http://www.bloomberg.com/tv/
Step 6 Run the following command in terminal as an ordinary user:
rtmpdump -r rtmpt://cp87869.live.edgefcs.net/live \ -a live \ -y us_300@21006 \ -W http://player.ooyala.com/static/cacheable/29d28e187072cf05af879e362d57b42d/player_v2.swf \ -p http://www.bloomberg.com/tv/ \ -f "LNX 10,1,82,76" \ -o ~/bloomberg.flv \ -V \ -B 600 \ --live
Here we added the option “— live” to make utility work right.
The address of streaming broadcasting is: http://www.euronews.net/news/streaming-live/
“rtmpsuck” gives us the next:
app: rtpeuronewslive flashVer: LNX 10,1,82,76 swfUrl: http://www.euronews.net/media/player_live_1_7.swf tcUrl: rtmp://178.32.100.43:1935/rtpeuronewslive pageUrl: http://www.euronews.net/news/streaming-live/ Playpath: eng_euronews-flash-750.sdp
so our command will be:
rtmpdump -r rtmp://178.32.100.43:1935/rtpeuronewslive \ -a rtpeuronewslive \ -y eng_euronews-flash-750.sdp \ -W http://www.euronews.net/media/player_live_1_7.swf \ -p http://www.euronews.net/news/streaming-live \ -f "LNX 10,1,82,76" \ -o ~/euronews.flv \ -B 600
There are many good programs you can find on this page: http://www.dw-world.de/dw/0,,4756,00.html
But if you try above technique, disappointment will wait for you. The reason for this is the video server is broadcasting on a different port. If you look into the source code of “rtmpsuck” you can see that default port of RTMP server (1935) is hard-coded, and that is why “rtmpsuck” is not a helper to us in this case.
The tool that will help us is called “tcpdump.” It is a console network sniffer. The nice feature of this tool is that it can show only printable symbols contained in network packets, which is handy for capturing web pages and this kind of stuff. If this tool is not yet installed on your system, you should do it now. The next utility is “grep” which helps to print lines matching a pattern which can be set.
Let’s get one of the excellent programs about lifestyle Europe, which is called “Euromaxx.” We assume that RTMP proxy server is not running and redirection traffic is turned off.
Step 1 Run as a “root” in terminal next set of commands:
tcpdump -ieth0 -nn -A |grep -e"rtmp" -e"connect" -e"play">/euromaxx.txt
It means that strings which included patterns (rtmp, connect or play) containing in network traffic and flowing trough network interface (eth0 in my case) will be recorded in file “euromaxx.txt,” which will be located in root directory (“/”).
Step 2 As an ordinary user, open in Firefox page: http://mediacenter.dw-world.de/english/video/#!/93184/euromaxx/Program=7555 and start to play the video. Wait a moment for the video to start to play, click the “pause” button on the built-in player, and click the “Update page” button on Firefox. Repeat this action 4 times.
Step 3 Go to root terminal and break running commands (Ctrl+C).
Step 4 Open the file “euromaxx.txt” in text editor and find piece of text:
connect.?..........app.. a4337/dwwod1/..flashVer...LNX 10,1,82,76..swfUrl..;http://mediacenter.dw-world.de/player/flash/media.player.swf..tcUrl..*rtmpt://tvone.fcod.llnwd.net/a4337/dwwod1/..fpad....capabilities.@m........audioCodecs.@.........videoCodecs..@o....... videoFunction.?.........pageUrl..Khttp://mediacenter.dw-world.de/english/video/#!/93184/euromaxx/Program=7555..object.Encoding.@......... ................closeStream.....................H.....P.....play............;mp4:dwtv_video/flv/eme/emagen100311-euromaxx01ep_sd_avc.mp4
Now you can easily determinate options for “rtmpdump”.
Step 5 Run command in terminal as ordinary user:
rtmpdump -r rtmpt://tvone.fcod.llnwd.net/a4337/dwwod1/ \ -a a4337/dwwod1/ \ -y mp4:dwtv_video/flv/eme/emagen100311-euromaxx01ep_sd_avc.mp4 \ -f "LNX 10,1,82,76" \ -W http://mediacenter.dw-world.de/player/flash/media.player.swf \ -p http://mediacenter.dw-world.de/english/video/#!/93184/euromaxx/Program=7555 \ -o ~/euromaxx.flv
After a while you will find the recorded program in your home directory.
The pitfall of this technique is that you can meet dots in an inappropriate place in the string. The reason for this is the fact that the text string, which should be continuous, is situated in two network packets and “tcpdump” changes unprintable symbols to dots. So, if something goes wrong, then place the key -V into you “rtmpdump” command and look at the debug messages. If “rtmpdump” can’t even connect to the server, then the reason in this case is rather a wrong URL.
There is a natural desire to record some program on a schedule (placing recording script for example in “cron”). If you will use the same file name of a recorded video program, then you will rewrite the previous one. In order to avoid this, it is very convenient to use the file name which contains the name of the broadcasting server, including the date and time of the recording. The next script shows the usage of this trick for our first TV broadcasting example:
#!/bin/bash BASENAME="rt" FILENAME="$BASENAME"_`date +%Y-%m-%d_%H%M%S`.flv rtmpdump -r rtmp://rt.fms.visionip.tv/live \ -y RT_US_3 \ -o ~/$FILENAME \ -B 1200
Exercise 2: Write a script for the scheduler in order to record a program which was yesterday in the last video on demand example using this hint:
YESTERDAY=$(date -d yesterday +"%d%m%y")
The answers will appear elsewhere in this issue of magazine. Also, you can find more information about streaming media recording on this site http://all-streaming-media.com/
http://www.chambersandpartners.com/
http://www.chambersandpartners.com/global-comparisontable
| 28 | Morgan, Lewis & Bockius LLP | Global Firm (USA) with 29 offices in 11 countries | Global-wide, Latin America-wide, Middle East-wide, Belgium, Kazakhstan, Russia, Singapore, United Arab Emirates, USA | Capital Markets: Structured Finance, Securitisation & Derivatives, Commercial Contracts, Employment, Immigration | Citi, Credit Suisse, Morgan Stanley, Barclays | Automobiles & Parts, Insurance, Media, Pharmaceuticals & Life Sciences, Telecommunications, Travel & Leisure | 
USA: Intellectual Property: Patent (Band 4)
【钱伯斯是什么】
所谓“2015钱伯斯排名”,是指著名法律评级机构钱伯斯(Chambers and Partners)在其发布的《2015亚太法律指南》(2015Asia-Pacific Guide)中评出的2015年亚太地区律所排名。
钱伯斯,是一家总部位于英国伦敦的法律评级机构,自1969年开始向世界发布不同国家的律所与律师排名,其通过严谨的调研和评价体系,评选出各个法律领域的全球知名律师事务所和顶尖级律师,成为全球客户寻求高端法律服务最值得信赖的权威参考之一,被广泛视为业界的基准。钱伯斯的中国榜单与研究也已走过九个年头。
钱伯斯有句注明的slogan为“No one can‘buy their way in’”,可谓是其榜单的最高目标与最佳写照。
【钱伯斯排名中的排名类型】
钱伯斯的主体榜单分为6档,Band 1 –Band 6。Band 1为最优,这不代表排在较低档次的律所或律师不好,能够上榜都已是颇具实力的表现,只是较低档次的入选者在某方面与较高排名者仍有些差距。
此外,钱伯斯不是每个榜单都是会排满6个档次,只有在法律高度发达和竞争激烈领域才会有6档或者接近6档的榜单出现,比如像Asia Guide中Australia的Dispute Resolution争端解决领域(5个band)或是UK Guide中London Tax的领域(6个band)。对于有些法律市场容量非常小的领域,出于宁缺毋滥的原则,甚至会出现无一律所上榜的情况,这也不足为奇。
钱伯斯在律师排名方面除了上述以数字等级排列的榜单外,还有一些特殊的排名,其中包括“Senior Statesmen业界元老 ”、“Star Individuals业界明星”、“Eminent Practitioners业界贤达”、 “Up-and-Coming Individuals潜质律师”、“Associatesto Watch后起之秀”等。这其中前几类主要针对资深合伙人而设,比如“Star Individuals业界明星”通常指业内最为出色的明星律师。 “Eminent Practitioners业界贤达”通常指那些经验丰富、但更多将精力转向客户维系和团队管理的杰出律师。除了资深律师外钱伯斯对青年律师也一直很关注。“Up-and-Coming Individuals潜质律师”、“Associatesto Watch后起之秀”正是两类最值得年轻律师朋友们注意的个人排名,分别针对的是合伙人和associate 级别的新晋律师,这两个分类是许多上榜律师都曾经历过的阶段,可以说它们是登上钱伯斯榜单的第一步。
【钱伯斯排名是如何产生的】
钱伯斯的研究团队全部常驻伦敦。研究员主要通过公开市场领域的信息搜集、申报材料研究、律师以及客户采访(以电话或者邮件形式)等手段对目标范围内的律师和律所进行研究。
个人排名 | 研究员会根据律师的法律知识、经验、专长、效率、勤奋程度以及客户服务水平等几个维度来考察律师个人的水平。以上各个维度的优劣判别主要通过与活跃的市场人士(主要是客户)的访谈以及对近期case业绩的评估来做出。初步的排名结果还会由研究员和编辑进行分析讨论,综合各方因素后确定最终排名。在需要的时候,还可针对少数疑问做一些补充研究。
律所排名 | 排名方式和角度与个人排名大致相同,但还要兼顾团队协作、内部机制和人员变动等方面,综合考虑该业务部门的广度和深度。不难发现,律所排名会和该所的律师排名成部分正相关,这也可以理解,因为上榜优秀个人律师越多,也可以侧面反映这些律师所属律所(部门)的实力越强。当然,也存在有些所的个人律师上榜,而律所无缘榜单的情况,这种情况则说明钱伯斯对其个别律师表示认可,而律所的整体实力仍需努力。需要指出的是,钱伯斯的律所排名仅针对的是该所相应的业务部门,比如A律所排在中国榜单某领域的band 2,仅能代表该所在该领域的团队实力,而不能反映该所的在其他领域或是全部的实力。
无论是律师个人还是律所排名,钱伯斯并没有一个明确的硬性规定来划定入榜界限或者不同band 之间的界限。在排名中通常会有一个横向比较的过程。通过之前的各个维度的考量以及定量和定性分析,研究员可以充分了解律所/个人的去年活跃程度,知道哪些律所和律师的业务情况相较于他人或者整体市场呈上升/下滑趋势,以此来对往年的榜单进行修正,以制作出更反映实际市场情况的榜单来。
【钱伯斯排名中都有哪些榜单】
钱伯斯排名首先将律所区分为中资律所和外资律所,相对应的中国榜单分别是PRC Firms 和 International Firms。
其次,钱伯斯将法律市场细分为不同的领域或细分领域。从2015年的钱伯斯榜单(中资律所)来看,排名覆盖了从“Banking and Finance银行金融”到“TMT”通信媒体的近20个大领域。由于各个法律领域的特点不同,不少榜单还有子榜单,比如“Capital Market资本市场”就分为“Capital Market: Debt & Equity资本市场:债务与股权”和“CapitalMarket: Securitization & Derivatives资本市场:资产证券化与衍生品”,而“债务与股权”部分又细分为“国内发行”和“香港及海外发行”两块。
另外,由于法律业务领域是不断变化发展的,因此钱伯斯的榜单也不是一成不变的,会随着实际法律需求和趋势做出相应调整。有时根据业务需求会添加新的榜单,有的时候会拆分榜单,但整个中国地区榜单的基本框架和研究方法目前仍保持不变。
此外,钱伯斯从2013年起连续三年发布了私人财富管理法律服务榜单。令人遗憾的是,目前没有中国律师事务所入选该榜单,但包括陈凯(Kai Chen)、王芳(Fang Wang)在内的多名律师以个人名义登陆该榜单,预示着一个向上的趋势。
以下表格可帮助您确定哪个选项最贴近您的需求:
| 选项 | G Suite SMTP 中继(推荐) | Gmail SMTP 服务器 | 受限 Gmail SMTP 服务器 | 
|---|---|---|---|
| SMTP 服务的完全限定域名 | smtp-relay.gmail.com | smtp.gmail.com | aspmx.l.google.com | 
| 配置要求 | 端口:25、465 或 587 可选 SSL/TLS。 需要一个或多个静态 IP 地址。 | 端口:465(需要 SSL) 端口:587(需要 TLS) 允许动态 IP | 端口:25 无需 TLS 允许动态 IP 只能向 Gmail 或 G Suite 用户发送邮件 | 
| yaoqiu身份验证 | IP 地址提供身份验证。 | 需要验证您的完整 Gmail 或 G Suite 电子邮件地址 | 不需要。 | 
| 绕过反垃圾邮件 | 不。可疑的电子邮件可能被过滤。 | 不。可疑的电子邮件可能被过滤。 | 不。可疑的电子邮件可能被过滤。 | 
| 发送限制 | 针对已注册的 G Suite 用户的限制。 已注册的用户每天最多能够向 10,000 名收件人中继邮件。 要了解完整的 SMTP 中继限制,请参阅 SMTP 中继服务的发送限制。 | 2000 封邮件/每天。有关详情,请参阅发送限制。 | 将根据每个用户的接收限制。 | 
Login into he ssh server
touch ~/.hushlogin