cluster-threading-net-server.js 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. const cluster = require('cluster')
  2. const ldap = require('ldapjs')
  3. const net = require('net')
  4. const os = require('os')
  5. const threads = []
  6. threads.getNext = function () {
  7. return (Math.floor(Math.random() * this.length))
  8. }
  9. const serverOptions = {
  10. port: 1389
  11. }
  12. if (cluster.isMaster) {
  13. const server = net.createServer(serverOptions, (socket) => {
  14. socket.pause()
  15. console.log('ldapjs client requesting connection')
  16. const routeTo = threads.getNext()
  17. threads[routeTo].send({ type: 'connection' }, socket)
  18. })
  19. for (let i = 0; i < os.cpus().length; i++) {
  20. const thread = cluster.fork({
  21. id: i
  22. })
  23. thread.id = i
  24. thread.on('message', function () {
  25. })
  26. threads.push(thread)
  27. }
  28. server.listen(serverOptions.port, function () {
  29. console.log('ldapjs listening at ldap://127.0.0.1:' + serverOptions.port)
  30. })
  31. } else {
  32. const server = ldap.createServer(serverOptions)
  33. const threadId = process.env.id
  34. process.on('message', (msg, socket) => {
  35. switch (msg.type) {
  36. case 'connection':
  37. server.newConnection(socket)
  38. socket.resume()
  39. console.log('ldapjs client connection accepted on ' + threadId.toString())
  40. }
  41. })
  42. server.search('dc=example', function (req, res) {
  43. console.log('ldapjs search initiated on ' + threadId.toString())
  44. const obj = {
  45. dn: req.dn.toString(),
  46. attributes: {
  47. objectclass: ['organization', 'top'],
  48. o: 'example'
  49. }
  50. }
  51. if (req.filter.matches(obj.attributes)) { res.send(obj) }
  52. res.end()
  53. })
  54. }