##// END OF EJS Templates
improve default ipc file locations...
MinRK -
Show More
@@ -62,6 +62,7 b' kernel_aliases.update({'
62 62 'stdin' : 'KernelApp.stdin_port',
63 63 'f' : 'KernelApp.connection_file',
64 64 'parent': 'KernelApp.parent',
65 'transport': 'KernelApp.transport',
65 66 })
66 67 if sys.platform.startswith('win'):
67 68 kernel_aliases['interrupt'] = 'KernelApp.interrupt'
@@ -98,7 +99,6 b' class KernelApp(BaseIPythonApplication):'
98 99 heartbeat = Instance(Heartbeat)
99 100 session = Instance('IPython.zmq.session.Session')
100 101 ports = Dict()
101 _full_connection_file = Unicode()
102 102
103 103 # inherit config file name from parent:
104 104 parent_appname = Unicode(config=True)
@@ -112,8 +112,16 b' class KernelApp(BaseIPythonApplication):'
112 112
113 113 # connection info:
114 114 transport = CaselessStrEnum(['tcp', 'ipc'], default_value='tcp', config=True)
115 ip = Unicode(LOCALHOST, config=True,
115 ip = Unicode(config=True,
116 116 help="Set the IP or interface on which the kernel will listen.")
117 def _ip_default(self):
118 if self.transport == 'ipc':
119 if self.connection_file:
120 return os.path.splitext(self.abs_connection_file)[0] + '-ipc'
121 else:
122 return 'kernel-ipc'
123 else:
124 return LOCALHOST
117 125 hb_port = Integer(0, config=True, help="set the heartbeat port [default: random]")
118 126 shell_port = Integer(0, config=True, help="set the shell (ROUTER) port [default: random]")
119 127 iopub_port = Integer(0, config=True, help="set the iopub (PUB) port [default: random]")
@@ -122,9 +130,16 b' class KernelApp(BaseIPythonApplication):'
122 130 help="""JSON file in which to store connection info [default: kernel-<pid>.json]
123 131
124 132 This file will contain the IP, ports, and authentication key needed to connect
125 clients to this kernel. By default, this file will be created in the security-dir
133 clients to this kernel. By default, this file will be created in the security dir
126 134 of the current profile, but can be specified by absolute path.
127 135 """)
136 @property
137 def abs_connection_file(self):
138 if os.path.basename(self.connection_file) == self.connection_file:
139 return os.path.join(self.profile_dir.security_dir, self.connection_file)
140 else:
141 return self.connection_file
142
128 143
129 144 # streams, etc.
130 145 no_stdout = Bool(False, config=True, help="redirect stdout to the null device")
@@ -141,7 +156,7 b' class KernelApp(BaseIPythonApplication):'
141 156 """)
142 157 interrupt = Integer(0, config=True,
143 158 help="""ONLY USED ON WINDOWS
144 Interrupt this process when the parent is signalled.
159 Interrupt this process when the parent is signaled.
145 160 """)
146 161
147 162 def init_crash_handler(self):
@@ -158,11 +173,20 b' class KernelApp(BaseIPythonApplication):'
158 173
159 174 def _bind_socket(self, s, port):
160 175 iface = '%s://%s' % (self.transport, self.ip)
161 if port <= 0 and self.transport == 'tcp':
162 port = s.bind_to_random_port(iface)
163 else:
164 c = ':' if self.transport == 'tcp' else '-'
165 s.bind(iface + c + str(port))
176 if self.transport == 'tcp':
177 if port <= 0:
178 port = s.bind_to_random_port(iface)
179 else:
180 s.bind("tcp://%s:%i" % (self.ip, port))
181 elif self.transport == 'ipc':
182 if port <= 0:
183 for port in range(1,1024):
184 path = "%s-%i" % (self.ip, port)
185 if not os.path.exists(path):
186 break
187 else:
188 path = "%s-%i" % (self.ip, port)
189 s.bind("ipc://%s" % path)
166 190 return port
167 191
168 192 def load_connection_file(self):
@@ -179,7 +203,7 b' class KernelApp(BaseIPythonApplication):'
179 203 s = f.read()
180 204 cfg = json.loads(s)
181 205 self.transport = cfg.get('transport', self.transport)
182 if self.ip == LOCALHOST and 'ip' in cfg:
206 if self.ip == self._ip_default() and 'ip' in cfg:
183 207 # not overridden by config or cl_args
184 208 self.ip = cfg['ip']
185 209 for channel in ('hb', 'shell', 'iopub', 'stdin'):
@@ -192,19 +216,15 b' class KernelApp(BaseIPythonApplication):'
192 216
193 217 def write_connection_file(self):
194 218 """write connection info to JSON file"""
195 if os.path.basename(self.connection_file) == self.connection_file:
196 cf = os.path.join(self.profile_dir.security_dir, self.connection_file)
197 else:
198 cf = self.connection_file
219 cf = self.abs_connection_file
220 self.log.debug("Writing connection file: %s", cf)
199 221 write_connection_file(cf, ip=self.ip, key=self.session.key, transport=self.transport,
200 222 shell_port=self.shell_port, stdin_port=self.stdin_port, hb_port=self.hb_port,
201 223 iopub_port=self.iopub_port)
202
203 self._full_connection_file = cf
204 224
205 225 def cleanup_connection_file(self):
206 cf = self._full_connection_file
207 self.log.debug("cleaning up connection file: %r", cf)
226 cf = self.abs_connection_file
227 self.log.debug("Cleaning up connection file: %s", cf)
208 228 try:
209 229 os.remove(cf)
210 230 except (IOError, OSError):
@@ -684,7 +684,20 b' class KernelManager(Configurable):'
684 684
685 685 transport = CaselessStrEnum(['tcp', 'ipc'], default_value='tcp', config=True)
686 686
687 ip = Unicode(LOCALHOST, config=True)
687 ip = Unicode(LOCALHOST, config=True,
688 help="""Set the kernel\'s IP address [default localhost].
689 If the IP address is something other than localhost, then
690 Consoles on other machines will be able to connect
691 to the Kernel, so be careful!"""
692 )
693 def _ip_default(self):
694 if self.transport == 'ipc':
695 if self.connection_file:
696 return os.path.splitext(self.connection_file)[0] + '-ipc'
697 else:
698 return 'kernel-ipc'
699 else:
700 return LOCALHOST
688 701 def _ip_changed(self, name, old, new):
689 702 if new == '*':
690 703 self.ip = '0.0.0.0'
@@ -706,8 +719,8 b' class KernelManager(Configurable):'
706 719 _stdin_channel = Any
707 720 _hb_channel = Any
708 721 _connection_file_written=Bool(False)
709
710 def __del__(self):
722
723 def __del__(self):
711 724 self.cleanup_connection_file()
712 725
713 726 #--------------------------------------------------------------------------
General Comments 0
You need to be logged in to leave comments. Login now