Giter Club home page Giter Club logo

Comments (7)

McBane87 avatar McBane87 commented on September 2, 2024
WARNING: Cannot write log file: /var/log/squid/cache.log,
/var/log/squid/cache.log: Permission denied,
         messages will be sent to 'stderr'.,
[...]
2021/01/10 18:43:16| Set Current Directory to /var/spool/squid,
fopen: Permission denied,
[...]
2021/01/10 18:43:17| logfileHandleWrite: daemon:/var/log/squid/access.log: error writing ((32) Broken pipe)

Can you please check permission of those directries on your host?

  • /storage/squid/log
  • /var/media/external/temp/squid/spool

They need to be writeable for a user with UID 13

2021/01/10 18:43:16| pinger: Unable to start ICMP pinger.,
2021/01/10 18:43:16| Open  icmp_sock: (1) Operation not permitted
[...]
2021/01/10 18:43:16| FATAL: pinger: Unable to open any ICMP sockets.

Also looks like some kind of permission issue. But I'm not sure why.
I don't have any aarch64 system myself for testing.
Can you try the arm32v7 image instead? Is this throwing the same errors?

from docker-squid-proxy.

sinancetinkaya avatar sinancetinkaya commented on September 2, 2024
WARNING: Cannot write log file: /var/log/squid/cache.log,
/var/log/squid/cache.log: Permission denied,
         messages will be sent to 'stderr'.,
[...]
2021/01/10 18:43:16| Set Current Directory to /var/spool/squid,
fopen: Permission denied,
[...]
2021/01/10 18:43:17| logfileHandleWrite: daemon:/var/log/squid/access.log: error writing ((32) Broken pipe)

Can you please check permission of those directries on your host?

* /storage/squid/log

* /var/media/external/temp/squid/spool
CoreELEC:~ # ls -l /storage/squid
total 2
drwxr-xr-x    2 root     root          1024 Jan 10 18:43 log
drwxr-xr-x    4 root     root          1024 Jan 10 18:43 squid
CoreELEC:~ # ls -l /var/media/external/temp/squid/
total 4
drwxr-xr-x    2 root     root          4096 Jan 10 18:31 spool

They need to be writeable for a user with UID 13

2021/01/10 18:43:16| pinger: Unable to start ICMP pinger.,
2021/01/10 18:43:16| Open  icmp_sock: (1) Operation not permitted
[...]
2021/01/10 18:43:16| FATAL: pinger: Unable to open any ICMP sockets.

Also looks like some kind of permission issue. But I'm not sure why.
I don't have any aarch64 system myself for testing.
Can you try the arm32v7 image instead? Is this throwing the same errors?

my device doesn't have a user with UID 13.
But I got the same error with UID 0 (root) as well.
I'll try arm32v7 image

from docker-squid-proxy.

sinancetinkaya avatar sinancetinkaya commented on September 2, 2024
CoreELEC:~ # docker create \
>   --name squid \
>   -e TZ=Europe/Istanbul \
>   -e PROXY_UID=0 \
>   -e PROXY_GID=0 \
>   -v /storage/squid/squid:/etc/squid \
>   -v /storage/squid/log:/var/log/squid \
>   -v /var/media/external/temp/squid/spool:/var/spool/squid \
>   -p 3128:3128 \
>   -p 3129:3129 \
>   distahl/squid:buster-arm32v7
Unable to find image 'distahl/squid:buster-arm32v7' locally
buster-arm32v7: Pulling from distahl/squid
c06905228d4f: Pull complete
fefd33730216: Pull complete
ea075e32ee62: Pull complete
7321359241f5: Pull complete
ee4d5df8d95b: Pull complete
f41ebae0ece1: Pull complete
8c5676735a31: Pull complete
ea6ba862b298: Pull complete
7e09136a00e3: Pull complete
1b88f6d64f45: Pull complete
73b1c5774bb3: Pull complete
bfb92b37af30: Pull complete
4c5b8501d068: Pull complete
Digest: sha256:42f54729533582f1adf3018cbf95c29209948da8e38c343e9ee88fe378ab10e9
Status: Downloaded newer image for distahl/squid:buster-arm32v7
Error response from daemon: Conflict. The container name "/squid" is already in use by container "425be190cd367da0e0e0e45cf03c3da7e2a9a3a8100683fbc1eab0eebf9a6dc8". You have to remove (or rename) that container to be able to reuse that name.

removed previous squid container and tried again

CoreELEC:~ # docker create \
>   --name squid \
>   -e TZ=Europe/Istanbul \
>   -e PROXY_UID=0 \
>   -e PROXY_GID=0 \
>   -v /storage/squid/squid:/etc/squid \
>   -v /storage/squid/log:/var/log/squid \
>   -v /var/media/external/temp/squid/spool:/var/spool/squid \
>   -p 3128:3128 \
>   -p 3129:3129 \
>   distahl/squid:buster-arm32v7
6acaed6958d2549e57fa22c0dde97eb66744b94ffbb4c8444f7a3c5efab0ffea
###########################################################,
No userdefined /etc/squid/squid.conf found. Will now copy the dist files.,
###########################################################,
'/etc/squid.dist/squid.conf' -> '/etc/squid/squid.conf',
'/etc/squid.dist/errorpage.css' -> '/etc/squid/errorpage.css',
'/etc/squid.dist/conf.d' -> '/etc/squid/conf.d',
'/etc/squid.dist/conf.d/debian.conf' -> '/etc/squid/conf.d/debian.conf',
'/etc/squid.dist/conf.d/ssl.conf' -> '/etc/squid/conf.d/ssl.conf',
'/etc/squid.dist/ssl-selfsigned.conf' -> '/etc/squid/ssl-selfsigned.conf',
###########################################################,
#########################################################################,
No /etc/squid/ssl directory found. Will now create selfsigned certificates.,
#########################################################################,
Generating a RSA private key,
............++++,
..........................................................................................................++++,
writing new private key to '/etc/squid/ssl/selfsigned.key',
-----,
#########################################################################,
##################################################,
Configured user id changed. Setting permissions...,
##################################################,
changed ownership of '/run/squid' from proxy to 0,
##################################################,
###################################################,
Configured group id changed. Setting permissions...,
###################################################,
changed group of '/run/squid' from proxy to 0,
###################################################,
2021/01/11 22:07:12| WARNING: BCP 177 violation. Detected non-functional IPv6 loopback.,
WARNING: Cannot write log file: /var/log/squid/cache.log,
/var/log/squid/cache.log: Permission denied,
         messages will be sent to 'stderr'.,
2021/01/11 22:07:12| Created PID file (/var/run/squid.pid),
2021/01/11 22:07:12| Set Current Directory to /var/spool/squid,
WARNING: Cannot write log file: /var/log/squid/cache.log,
/var/log/squid/cache.log: Permission denied,
         messages will be sent to 'stderr'.,
2021/01/11 22:07:12| WARNING: Closing open FD    2,
2021/01/11 22:07:12| Starting Squid Cache version 4.6 for arm-unknown-linux-gnueabihf...,
2021/01/11 22:07:12| Service Name: squid,
2021/01/11 22:07:12| Process ID 61,
2021/01/11 22:07:12| Process Roles: master worker,
2021/01/11 22:07:12| With 65535 file descriptors available,
2021/01/11 22:07:12| Initializing IP Cache...,
2021/01/11 22:07:12| DNS Socket created at 0.0.0.0, FD 7,
2021/01/11 22:07:12| Adding domain lan from /etc/resolv.conf,
2021/01/11 22:07:12| Adding nameserver 192.168.1.1 from /etc/resolv.conf,
2021/01/11 22:07:12| Logfile: opening log daemon:/var/log/squid/access.log,
2021/01/11 22:07:12| Logfile Daemon: opening log /var/log/squid/access.log,
2021/01/11 22:07:12| Local cache digest enabled; rebuild/rewrite every 3600/3600 sec,
2021/01/11 22:07:12| Store logging disabled,
2021/01/11 22:07:12| Swap maxSize 0 + 262144 KB, estimated 20164 objects,
2021/01/11 22:07:12| Target number of buckets: 1008,
2021/01/11 22:07:12| Using 8192 Store buckets,
2021/01/11 22:07:12| Max Mem  size: 262144 KB,
2021/01/11 22:07:12| Max Swap size: 0 KB,
2021/01/11 22:07:12| Using Least Load store dir selection,
2021/01/11 22:07:12| Set Current Directory to /var/spool/squid,
fopen: Permission denied,
2021/01/11 22:07:12| Finished loading MIME types and icons.,
2021/01/11 22:07:12| HTCP Disabled.,
2021/01/11 22:07:12| Pinger socket opened on FD 13,
2021/01/11 22:07:12| Squid plugin modules loaded: 0,
2021/01/11 22:07:12| Adaptation support is off.,
2021/01/11 22:07:12| Accepting HTTPS Socket connections at local=0.0.0.0:3129 remote=[::] FD 10 flags=9,
2021/01/11 22:07:12| Accepting HTTP Socket connections at local=0.0.0.0:3128 remote=[::] FD 11 flags=9,
2021/01/11 22:07:12| WARNING: BCP 177 violation. Detected non-functional IPv6 loopback.,
2021/01/11 22:07:12| pinger: Initialising ICMP pinger ...,
2021/01/11 22:07:12| Open  icmp_sock: (1) Operation not permitted,
2021/01/11 22:07:12| pinger: Unable to start ICMP pinger.,
2021/01/11 22:07:12| Open  icmp_sock: (1) Operation not permitted,
2021/01/11 22:07:12| pinger: Unable to start ICMPv6 pinger.,
2021/01/11 22:07:12| FATAL: pinger: Unable to open any ICMP sockets.,
2021/01/11 22:07:13| logfileHandleWrite: daemon:/var/log/squid/access.log: error writing ((32) Broken pipe),
2021/01/11 22:07:13| Closing HTTP(S) port 0.0.0.0:3129,
2021/01/11 22:07:13| Closing HTTP(S) port 0.0.0.0:3128,
2021/01/11 22:07:13| storeDirWriteCleanLogs: Starting...,
2021/01/11 22:07:13|   Finished.  Wrote 0 entries.,
2021/01/11 22:07:13|   Took 0.00 seconds (  0.00 entries/sec).,
2021/01/11 22:07:13| FATAL: I don't handle this error well!,
2021/01/11 22:07:13| Squid Cache (Version 4.6): Terminated abnormally.,
CPU Usage: 0.300 seconds = 0.290 user + 0.010 sys,
Maximum Resident Size: 77776 KB,
Page faults with physical i/o: 0,
2021/01/11 22:07:13| Removing PID file (/var/run/squid.pid),
2021/01/11 22:07:13| Closing Pinger socket on FD 13,

from docker-squid-proxy.

McBane87 avatar McBane87 commented on September 2, 2024

Hmm...Well there is definitely something wrong with permissions on your client. I've tested the arm32v7 image yesterday on my Raspberry and it was working fine. As I'm not able to look into your client to investigate myself, I'm afraid you have to find out yourself why this happens.

Some suggestions which could help.

=====

Please don't use any user id which could already exist inside the container. User id 0 is definitely already existing inside the container, because it is always the root user. You need to specify some user id which the container can use for a user named squid. Outside your container the user with id e.g. 13 doesn't need to be named squid. It can be any other user. The container dosen't care what happens outside as long as the permissions for the mounted directories/volumes outside are correctly set to be accessible/writeable by e.g. user id 13.
So best practice could be to create a new user (outside container) with a name you like (e.g. useradd -r -s/usr/sbin/nologin -M docker_squid). Then look inside your /etc/passwd and check which uid and gid this user got. Now change the permissions of your directories, you want to use as volumes for your container. And after that use those ids for creating the squid container.

=====

You can try to change the entrypoint of the image to /bin/bash -c 'while [ 1 == 1 ]; do sleep 10; done' or something else, which is running endlessly. This way you should be able to connect to the conatainer using docker exec -ti squid bash. Once you are inside the, newly created, container please run /start-squid.sh. It will most likely fail the same way as your logs above show, but this way you made the script create the initial directories/files. After that you can start to investigate why your permissions aren't working inside the container. So the hole create command should look like this (and yes, the arguments for bash are coming after the image name):

docker create   \
--name squid   \
-e TZ=Europe/Istanbul \
-e PROXY_UID=13 \
-e PROXY_GID=13 \
-v /docker/config/squid/etc:/etc/squid \
-v /docker/config/squid/etc:/var/log/squid \
-v /docker/config/squid/spool:/var/spool/squid \
-p 3128:3128 \
-p 3129:3129 \
--entrypoint /bin/bash \
distahl/squid:buster-arm32v7 \
-c 'while [ 1 == 1 ]; do sleep 10; done'

=====

Finally there is also an option for create, which should give your container all the privileges available, but this isn't good practice and should be avoided. Also, even if you use this option, you still need to make sure to use a correct user id and have set the correct permissions. So the option is: --privileged

from docker-squid-proxy.

srcKod avatar srcKod commented on September 2, 2024

my squid.conf

http_port 0.0.0.0:46001
icp_port 0

acl localnet src 0.0.0.1-0.255.255.255	        # RFC 1122 "this" network (LAN)
acl localnet src 10.0.0.0/8			# RFC 1918 local private network (LAN)
acl localnet src 100.64.0.0/10			# RFC 6598 shared address space (CGN)
acl localnet src 169.254.0.0/16 		# RFC 3927 link-local (directly plugged) machines
acl localnet src 172.16.0.0/12			# RFC 1918 local private network (LAN)
acl localnet src 192.168.0.0/16			# RFC 1918 local private network (LAN)
acl localnet src fc00::/7       		# RFC 4193 local private network range
acl localnet src fe80::/10      		# RFC 4291 link-local (directly plugged) machines

acl SSL_ports port 443
acl Safe_ports port 80			# http
acl Safe_ports port 21			# ftp
acl Safe_ports port 22			# ssh
acl Safe_ports port 443			# https
acl CONNECT method CONNECT

auth_param basic program /usr/lib/squid/basic_ncsa_auth /etc/squid/.htpasswd
auth_param basic children 15
auth_param basic realm Welcome to Proxy Server
auth_param basic credentialsttl 5 hours
auth_param basic casesensitive on
acl auth proxy_auth REQUIRED
http_access allow auth

http_access deny !Safe_ports
http_access deny CONNECT !SSL_ports

http_access allow localhost manager
http_access deny manager

http_access allow localnet
http_access allow localhost

http_access deny all

cache_dir ufs /var/spool/squid 500 16 256
coredump_dir /var/spool/squid

cache_effective_user proxy

refresh_pattern ^ftp:		1440	20%	10080
refresh_pattern ^gopher:	1440	0%	1440
refresh_pattern -i (/cgi-bin/|\?) 0	0%	0
refresh_pattern .		0	20%	4320

negative_ttl 0 
dns_v4_first on
#dns_nameservers 1.1.1.1
#dns_nameservers 8.8.8.8 8.8.4.4

positive_dns_ttl 8 hours
negative_dns_ttl 30 seconds

pinger_enable off
half_closed_clients off
quick_abort_min 0 KB
quick_abort_max 0 KB
quick_abort_pct 95

client_persistent_connections off
server_persistent_connections off

visible_hostname unknown
via off
forwarded_for transparent
httpd_suppress_version_string on

request_header_access Allow allow all 
request_header_access Authorization allow all 
request_header_access WWW-Authenticate allow all 
request_header_access Proxy-Authorization allow all 
request_header_access Proxy-Authenticate allow all 
request_header_access Cache-Control allow all 
request_header_access Content-Encoding allow all 
request_header_access Content-Length allow all 
request_header_access Content-Type allow all 
request_header_access Date allow all 
request_header_access Expires allow all 
request_header_access Host allow all 
request_header_access If-Modified-Since allow all 
request_header_access Last-Modified allow all 
request_header_access Location allow all 
request_header_access Pragma allow all 
request_header_access Accept allow all 
request_header_access Accept-Charset allow all 
request_header_access Accept-Encoding allow all 
request_header_access Accept-Language allow all 
request_header_access Content-Language allow all 
request_header_access Mime-Version allow all 
request_header_access Retry-After allow all 
request_header_access Title allow all 
request_header_access Connection allow all 
request_header_access Proxy-Connection allow all 
request_header_access User-Agent allow all 
request_header_access Cookie allow all 
request_header_access All deny all

my docker-compose.yml

version: '3.3'
services:
    squid:
        ports:
            - '46001:46001'
        image: 'distahl/squid:latest'
        volumes:
            - './config:/etc/squid'
            - './../squid_log:/var/log/squid' 
            - './../squid_cache:/var/spool/squid'
        environment:
            - PROXY_UID=1000
            - PROXY_GID=1000                  
        container_name: dsquid

1- host has user "squid" with UID=1000 & GID=1000
2- host volume directories owner and group set to "squid:squid" with UID=1000 & GID=1000
3- docker-compose up command executed under "squid" user with sudo privileges

sudo docker-compose up

the result

2021/02/11 16:02:03| Created PID file (/run/squid.pid)
2021/02/11 16:02:03| Set Current Directory to /var/spool/squid
2021/02/11 16:02:03| Starting Squid Cache version 4.13 for x86_64-pc-linux-gnu...
2021/02/11 16:02:03| Service Name: squid
2021/02/11 16:02:03| Process ID 37
2021/02/11 16:02:03| Process Roles: master worker
2021/02/11 16:02:03| With 65535 file descriptors available
2021/02/11 16:02:03| Initializing IP Cache...
2021/02/11 16:02:03| DNS Socket created at 0.0.0.0, FD 3
2021/02/11 16:02:03| Adding nameserver 127.0.0.11 from /etc/resolv.conf
2021/02/11 16:02:03| Adding ndots 1 from /etc/resolv.conf
2021/02/11 16:02:03| helperOpenServers: Starting 0/15 'basic_ncsa_auth' processes
2021/02/11 16:02:03| helperOpenServers: No 'basic_ncsa_auth' processes needed.
2021/02/11 16:02:03| Logfile: opening log daemon:/var/log/squid/access.log
2021/02/11 16:02:03| Logfile Daemon: opening log /var/log/squid/access.log
2021/02/11 16:02:04| Unlinkd pipe opened on FD 14
2021/02/11 16:02:04| Local cache digest enabled; rebuild/rewrite every 3600/3600 sec
2021/02/11 16:02:04| Store logging disabled
2021/02/11 16:02:04| Swap maxSize 512000 + 262144 KB, estimated 59549 objects
2021/02/11 16:02:04| Target number of buckets: 2977
2021/02/11 16:02:04| Using 8192 Store buckets
2021/02/11 16:02:04| Max Mem  size: 262144 KB
2021/02/11 16:02:04| Max Swap size: 512000 KB
2021/02/11 16:02:04| ERROR: /var/spool/squid/00: (2) No such file or directory
2021/02/11 16:02:04| Not currently OK to rewrite swap log.
2021/02/11 16:02:04| storeDirWriteCleanLogs: Operation aborted.
2021/02/11 16:02:04| FATAL: 	Failed to verify one of the swap directories, Check cache.log
	for details.  Run 'squid -z' to create swap directories
	if needed, or if running Squid for the first time.
2021/02/11 16:02:04| Squid Cache (Version 4.13): Terminated abnormally.
CPU Usage: 0.031 seconds = 0.014 user + 0.017 sys
Maximum Resident Size: 123808 KB
Page faults with physical i/o: 0
2021/02/11 16:02:04| Removing PID file (/run/squid.pid)

I even tried to run squid container with changed entrypoint to /bin/bash then run ./start-squid.sh with the same result
I think there is problem with the start-squid.sh when trying to create spool dirs because when I disable caching in squid.conf squid container run without problem and squid logs access.log && cache.log copied to host volume directory ./../squid_log

update:

I started the container with these lines commented in squid.conf to be able to access the conatiner bash

# cache_dir ufs /var/spool/squid 500 16 256
# coredump_dir /var/spool/squid
# cache_effective_user proxy

then after the container started I uncommented the lines in squid.conf on host volume directory ./config/squid.conf to enable the cache again then what I did

cd /var/spool/squid
/usr/sbin/squid -z -f /etc/squid/squid.conf

1- the spool directories created and copied to host volume directory ./../squid_cache
2- the owner of volume host directories is squid:squid
3- the owner of container directories proxy:proxy

which means start-squid.sh failed to create spool directories for some reason

I stoped squid container then

sudo docker-compose up

the result

2021/02/11 17:45:09| Created PID file (/run/squid.pid)
2021/02/11 17:45:09| Set Current Directory to /var/spool/squid
2021/02/11 17:45:09| Starting Squid Cache version 4.13 for x86_64-pc-linux-gnu...
2021/02/11 17:45:09| Service Name: squid
2021/02/11 17:45:09| Process ID 37
2021/02/11 17:45:09| Process Roles: master worker
2021/02/11 17:45:09| With 65535 file descriptors available
2021/02/11 17:45:09| Initializing IP Cache...
2021/02/11 17:45:09| DNS Socket created at 0.0.0.0, FD 3
2021/02/11 17:45:09| Adding nameserver 127.0.0.11 from /etc/resolv.conf
2021/02/11 17:45:09| Adding ndots 1 from /etc/resolv.conf
2021/02/11 17:45:09| helperOpenServers: Starting 0/15 'basic_ncsa_auth' processes
2021/02/11 17:45:09| helperOpenServers: No 'basic_ncsa_auth' processes needed.
2021/02/11 17:45:09| Logfile: opening log daemon:/var/log/squid/access.log
2021/02/11 17:45:09| Logfile Daemon: opening log /var/log/squid/access.log
2021/02/11 17:45:09| Unlinkd pipe opened on FD 14
2021/02/11 17:45:09| Local cache digest enabled; rebuild/rewrite every 3600/3600 sec
2021/02/11 17:45:09| Store logging disabled
2021/02/11 17:45:09| Swap maxSize 512000 + 262144 KB, estimated 59549 objects
2021/02/11 17:45:09| Target number of buckets: 2977
2021/02/11 17:45:09| Using 8192 Store buckets
2021/02/11 17:45:09| Max Mem  size: 262144 KB
2021/02/11 17:45:09| Max Swap size: 512000 KB
2021/02/11 17:45:09| Rebuilding storage in /var/spool/squid (no log)
2021/02/11 17:45:09| Using Least Load store dir selection
2021/02/11 17:45:09| Set Current Directory to /var/spool/squid
2021/02/11 17:45:09| Finished loading MIME types and icons.
2021/02/11 17:45:09| HTCP Disabled.
2021/02/11 17:45:09| Squid plugin modules loaded: 0
2021/02/11 17:45:09| Adaptation support is off.
2021/02/11 17:45:09| Accepting HTTP Socket connections at local=0.0.0.0:46001 remote=[::] FD 16 flags=9
2021/02/11 17:45:09| Configuring Parent dgost1/49152/0
2021/02/11 17:45:09| Configuring Parent dgost2/49153/0
2021/02/11 17:45:09| Configuring Parent dgost3/49154/0
2021/02/11 17:45:09| Configuring Parent dgost4/49155/0
2021/02/11 17:45:09| Configuring Parent dgost5/49156/0
2021/02/11 17:45:09| Configuring Parent dgost6/49157/0
2021/02/11 17:45:09| Done scanning /var/spool/squid dir (0 entries)
2021/02/11 17:45:09| Finished rebuilding storage from disk.
2021/02/11 17:45:09|         0 Entries scanned
2021/02/11 17:45:09|         0 Invalid entries.
2021/02/11 17:45:09|         0 With invalid flags.
2021/02/11 17:45:09|         0 Objects loaded.
2021/02/11 17:45:09|         0 Objects expired.
2021/02/11 17:45:09|         0 Objects cancelled.
2021/02/11 17:45:09|         0 Duplicate URLs purged.
2021/02/11 17:45:09|         0 Swapfile clashes avoided.
2021/02/11 17:45:09|   Took 0.14 seconds (  0.00 objects/sec).
2021/02/11 17:45:09| Beginning Validation Procedure
2021/02/11 17:45:09|   Completed Validation Procedure
2021/02/11 17:45:09|   Validated 0 Entries
2021/02/11 17:45:09|   store_swap_size = 0.00 KB
2021/02/11 17:45:10| storeLateRelease: released 0 objects

from docker-squid-proxy.

McBane87 avatar McBane87 commented on September 2, 2024

Closing because no reaction from initial poster within 1 month.

from docker-squid-proxy.

sinancetinkaya avatar sinancetinkaya commented on September 2, 2024

This was just a test. I gave up on docker-squid-proxy because my Linux knowledge is limited.

from docker-squid-proxy.

Related Issues (3)

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.