File: Zend_TimeSync-Working.xml

package info (click to toggle)
zendframework 1.12.9%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: jessie-kfreebsd
  • size: 133,584 kB
  • sloc: xml: 1,311,829; php: 570,173; sh: 170; makefile: 125; sql: 121
file content (283 lines) | stat: -rw-r--r-- 11,953 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
<?xml version="1.0" encoding="UTF-8"?>
<!-- Reviewed: no -->
<sect1 id="zend.timesync.working">
    <title>Working with Zend_TimeSync</title>

    <para>
        <classname>Zend_TimeSync</classname> can return the actual time from any given
        <emphasis>NTP</emphasis> or <emphasis>SNTP</emphasis> time server.
        It can automatically handle multiple servers and provides a simple interface.
    </para>

    <note>
        <para>
            All examples in this chapter use a public, generic time server:
            <emphasis>0.europe.pool.ntp.org</emphasis>. You should use a public, generic time server
            which is close to your application server. See <ulink
                url="http://www.pool.ntp.org">http://www.pool.ntp.org</ulink> for information.
        </para>
    </note>

    <sect2 id="zend.timesync.working.generic">
        <title>Generic Time Server Request</title>

        <para>
            Requesting the time from a time server is simple. First, you provide the time server
            from which you want to request the time.
        </para>

        <programlisting language="php"><![CDATA[
$server = new Zend_TimeSync('0.pool.ntp.org');

print $server->getDate()->getIso();
]]></programlisting>

        <para>
            So what is happening in the background of <classname>Zend_TimeSync</classname>? First
            the syntax of the time server is checked. In our example,
            '<emphasis>0.pool.ntp.org</emphasis>' is checked and recognised as a possible address
            for a time server. Then when calling <methodname>getDate()</methodname> the actual set
            time server is requested and it will return its own time.
            <classname>Zend_TimeSync</classname> then calculates the difference to the actual time
            of the server running the script and returns a <classname>Zend_Date</classname> object
            with the correct time.
        </para>

        <para>
            For details about <classname>Zend_Date</classname> and its methods see the <link
                linkend="zend.date.introduction"><classname>Zend_Date</classname>
                documentation</link>.
        </para>
    </sect2>

    <sect2 id="zend.timesync.working.multiple">
        <title>Multiple Time Servers</title>

        <para>
            Not all time servers are always available to return their time. Servers may be
            unavailable during maintenance, for example. When the time cannot be requested from the
            time server, you will get an exception.
        </para>

        <para>
            <classname>Zend_TimeSync</classname> is a simple solution that can handle multiple time
            servers and supports an automatic fallback mechanism. There are two supported ways; you
            can either specify an array of time servers when creating the instance, or you can add
            additional time servers to the instance using the <methodname>addServer()</methodname>
            method.
        </para>

        <programlisting language="php"><![CDATA[
$server = new Zend_TimeSync(array('0.pool.ntp.org',
                                  '1.pool.ntp.org',
                                  '2.pool.ntp.org'));
$server->addServer('3.pool.ntp.org');

print $server->getDate()->getIso();
]]></programlisting>

        <para>
            There is no limit to the number of time servers you can add. When a time server can not
            be reached, <classname>Zend_TimeSync</classname> will fallback and try to connect to the
            next time server.
        </para>

        <para>
            When you supply more than one time server- which is considered a best practice for
            <classname>Zend_TimeSync</classname>- you should name each server. You can name your
            servers with array keys, with the second parameter at instantiation, or with the second
            parameter when adding another time server.
        </para>

        <programlisting language="php"><![CDATA[
$server = new Zend_TimeSync(array('generic'  => '0.pool.ntp.org',
                                  'fallback' => '1.pool.ntp.org',
                                  'reserve'  => '2.pool.ntp.org'));
$server->addServer('3.pool.ntp.org', 'additional');

print $server->getDate()->getIso();
]]></programlisting>

        <para>
            Naming the time servers allows you to request a specific time server as we will see
            later in this chapter.
        </para>
    </sect2>

    <sect2 id="zend.timesync.working.protocol">
        <title>Protocols of Time Servers</title>

        <para>
            There are different types of time servers. Most public time servers use the
            <emphasis>NTP</emphasis> protocol. But there are other time synchronization
            protocols available.
        </para>

        <para>
            You set the proper protocol in the address of the time server. There are two
            protocols which are supported by <classname>Zend_TimeSync</classname>:
            <emphasis>NTP</emphasis> and <emphasis>SNTP</emphasis>. The default protocol is
            <emphasis>NTP</emphasis>. If you are using <emphasis>NTP</emphasis>, you can omit the
            protocol in the address as demonstrated in the previous examples.
        </para>

        <programlisting language="php"><![CDATA[
$server = new Zend_TimeSync(array('generic'  => 'ntp:\\0.pool.ntp.org',
                                  'fallback' => 'ntp:\\1.pool.ntp.org',
                                  'reserve'  => 'ntp:\\2.pool.ntp.org'));
$server->addServer('sntp:\\internal.myserver.com', 'additional');

print $server->getDate()->getIso();
]]></programlisting>

        <para>
            <classname>Zend_TimeSync</classname> can handle mixed time servers. So you are not
            restricted to only one protocol; you can add any server independently from its protocol.
        </para>
    </sect2>

    <sect2 id="zend.timesync.working.ports">
        <title>Using Ports for Time Servers</title>

        <para>
            As with every protocol within the world wide web, the <emphasis>NTP</emphasis> and
            <emphasis>SNTP</emphasis> protocols use standard ports. NTP uses port
            <emphasis>123</emphasis> and SNTP uses port <emphasis>37</emphasis>.
        </para>

        <para>
            But sometimes the port that the protocols use differs from the standard one. You can
            define the port which has to be used for each server within the address. Just add the
            number of the port after the address. If no port is defined, then
            <classname>Zend_TimeSync</classname> will use the standard port.
        </para>

        <programlisting language="php"><![CDATA[
$server = new Zend_TimeSync(array('generic'  => 'ntp:\\0.pool.ntp.org:200',
                                  'fallback' => 'ntp:\\1.pool.ntp.org'));
$server->addServer('sntp:\\internal.myserver.com:399', 'additional');

print $server->getDate()->getIso();
]]></programlisting>
    </sect2>

    <sect2 id="zend.timesync.working.options">
        <title>Time Servers Options</title>

        <para>
            There is only one option within <classname>Zend_TimeSync</classname> which will be used
            internally: <emphasis>timeout</emphasis>. You can set any self-defined option you are in
            need of and request it, however.
        </para>

        <para>
            The option <emphasis>timeout</emphasis> defines the number of seconds after which
            a connection is detected as broken when there was no response. The default value is
            <emphasis>1</emphasis>, which means that <classname>Zend_TimeSync</classname> will
            fallback to the next time server if the requested time server does not respond in one
            second.
        </para>

        <para>
            With the <methodname>setOptions()</methodname> method, you can set any option. This
            function accepts an array where the key is the option to set and the value is the value
            of that option. Any previously set option will be overwritten by the new value. If you
            want to know which options are set, use the <methodname>getOptions()</methodname>
            method. It accepts either a key which returns the given option if specified, or, if no
            key is set, it will return all set options.
        </para>

        <programlisting language="php"><![CDATA[
Zend_TimeSync::setOptions(array('timeout' => 3, 'myoption' => 'timesync'));
$server = new Zend_TimeSync(array('generic'  => 'ntp:\\0.pool.ntp.org',
                                  'fallback' => 'ntp:\\1.pool.ntp.org'));
$server->addServer('sntp:\\internal.myserver.com', 'additional');

print $server->getDate()->getIso();
print_r(Zend_TimeSync::getOptions();
print "Timeout = " . Zend_TimeSync::getOptions('timeout');
]]></programlisting>

        <para>
            As you can see, the options for <classname>Zend_TimeSync</classname> are static. Each
            instance of <classname>Zend_TimeSync</classname> will use the same options.
        </para>
    </sect2>

    <sect2 id="zend.timesync.working.different">
        <title>Using Different Time Servers</title>

        <para>
            <classname>Zend_TimeSync</classname>'s default behavior for requesting a time is to
            request it from the first given server. But sometimes it is useful to set a different
            time server from which to request the time. This can be done with the
            <methodname>setServer()</methodname> method. To define the used time server set the
            alias as a parameter within the method. To get the actual used time server call the
            <methodname>getServer()</methodname> method. It accepts an alias as a parameter which
            defines the time server to be returned. If no parameter is given, the current time
            server will be returned.
        </para>

        <programlisting language="php"><![CDATA[
$server = new Zend_TimeSync(array('generic'  => 'ntp:\\0.pool.ntp.org',
                                  'fallback' => 'ntp:\\1.pool.ntp.org'));
$server->addServer('sntp:\\internal.myserver.com', 'additional');

$actual = $server->getServer();
$server = $server->setServer('additional');
]]></programlisting>
    </sect2>

    <sect2 id="zend.timesync.working.informations">
        <title>Information from Time Servers</title>

        <para>
            Time servers not only offer the time itself, but also additional information. You can
            get this information with the <methodname>getInfo()</methodname> method.
        </para>

        <programlisting language="php"><![CDATA[
$server = new Zend_TimeSync(array('generic'  => 'ntp:\\0.pool.ntp.org',
                                  'fallback' => 'ntp:\\1.pool.ntp.org'));

print_r ($server->getInfo());
]]></programlisting>

        <para>
            The returned information differs with the protocol used and can also differ with the
            server used.
        </para>
    </sect2>

    <sect2 id="zend.timesync.working.exceptions">
        <title>Handling Exceptions</title>

        <para>
            Exceptions are collected for all time servers and returned as an array. So you can
            iterate through all thrown exceptions as shown in the following example:
        </para>

        <programlisting language="php"><![CDATA[
$serverlist = array(
        // invalid servers
        'invalid_a'  => 'ntp://a.foo.bar.org',
        'invalid_b'  => 'sntp://b.foo.bar.org',
);

$server = new Zend_TimeSync($serverlist);

try {
    $result = $server->getDate();
    echo $result->getIso();
} catch (Zend_TimeSync_Exception $e) {

    $exceptions = $e->get();

    foreach ($exceptions as $key => $myException) {
        echo $myException->getMessage();
        echo '<br />';
    }
}
]]></programlisting>
    </sect2>
</sect1>